From: Subject: Date: Thu, 5 May 2011 10:50:06 +0200 MIME-Version: 1.0 Content-Type: multipart/related; type="text/html"; boundary="----=_NextPart_000_00D3_01CC0B12.32205B80" X-MimeOLE: Produced By Microsoft MimeOLE V6.00.2900.6090 This is a multi-part message in MIME format. ------=_NextPart_000_00D3_01CC0B12.32205B80 Content-Type: text/html; charset="Windows-1252" Content-Transfer-Encoding: quoted-printable Content-Location: mhtml:http://www.kefo.rs/uploaded/dokument.24.mht 3D""=20=20

Your Product choice


=

=20

=20 =20

Products

3D""=20

------=_NextPart_000_00D3_01CC0B12.32205B80 Content-Type: image/gif Content-Transfer-Encoding: base64 Content-Location: http://www.heidolph-instruments.co.uk/clear.gif R0lGODlhAQABAIAAAP///wAAACH5BAEAAAAALAAAAAABAAEAAAICRAEAO2lmDQ== ------=_NextPart_000_00D3_01CC0B12.32205B80 Content-Type: image/gif Content-Transfer-Encoding: base64 Content-Location: http://www.heidolph-instruments.co.uk/fileadmin/templates/img/logo.gif R0lGODlhqgAyAOYAAOdgHGVun5iev/318MzP31pjmARFqfHy9nuCrD1Ih7G1zut+RkNNinN6p/Gk fPrh1OlrK/CccVNclPOtif7+/mtzo0lTjX+GsDlFhbm90/CZbPbEqhtDl4ySt/X1+Nze6U5XkJCW uuyMW+2GUGFqnM/R4MLF2ZSZvPnXxqClw+pyNIeNtPOwjvS0kuluL/v7/L7A1u2IVOt4Pa2xy+p1 Odja5p2iwu+UZfzu5eXm7z9KiPnVwvGfdGdvoMbI29BbKtbX5f3x6unq8NLU4vjSvfjPufvl2fzo 3fKngOyCSfrcy6quyZqfwKSoxvzr4vW+oevs8ufo8O6QXf759uhlI/KrhPfKsffNtYSKsuHi7AFG rMDD1/j4+uhoJ/S3l/79++/w9e7v9Prf0PW7nbW50ahTP/bCpsrM3VBDcPfIrvzq4HpLWaaryGNG Zf/7+eDh697f6o1OT+dfHFhXiOPk7cnL3JV3hWRoluBfIOnk6KSgufW4l5aGnnxylABGrf///yH5 BAAAAAAALAAAAACqADIAAAf/gH+Cg4SFhoeIiYqLjI2Oj5CRkpOUlZaXmJmam5ydnp+dFAQ2HRUB WDYwUKCsra6YQBcJfrS1HX9AMCYUr72+v4MHCLXEtDaDXDMEwMzNnEM6xcVnhUApztjZkWQc0sUe hjUnvNrl5oR1Bt7EGIhCt+fx2Tmz67UkiSZN8vzMAfbEGihakaOfQVdnABIToAjMhUI5BEiUqKCQ gokSCzoigHFfoosTyTzygFGARkclS/QiYc/Aii0lhpxEhCULITbFQhSKRozLowrEECjiSeuaowzE OBx49KHYkFdN1yEQMmWDAw0t1CgqgYUQUGLLBgEpFuARF3W1KiIaS+zDIywB/yE1IQail411M/4Y UQGgb98niuoKeoGWVjtCAooZbWSCmIFViBLXKgCJAbElkHoQg+fqa7ETf4JA8EvaTKIKkLcUE0rI QjE4j3IQmE2ghqICxHQ68lFs5qIoxUz0AiHNAi8HpElDcBM57IpiagVFnUzoQIYVAXqc8FGI9uyl 0m30qKDAw3RaKgWJEmAKgQLIgjoQk/DCO4EXYZY0CNDh5JKkFIQxAwIBrPDGJ95g9gcNyZGGQmQZ CFIPLQb4NMhcxID2hxAXdFMMCOkRUIxNH/xDTAFMEKODIAcIQFQtBhwjiASbqVYLAylM6AcHajVA TAUdeFhLXp14Y2GDpF2ByP8J+5RQjAEYJCBlAkLS8hQMOhaTwCohEGPBHzVkSUuVAn1Aoz37AEeM D8/B6E0C4FRZmIqeSCPBIAwiCcCDh5AQYZcK0amAFvPhRswxZ9KyQhYv2kNGmAox8Md/tRhHXKBb 8BaoH55cWktZgkSgZxfMGfKCFssYuqkfCJRQmAW2/TEDMT1AEZxmMIZwxglPwuFaLRIoYIKqtAjh Yy0XZKFlCgQcW4sA8rETALF+GOCJZ7TgIwgOozUI2CEw+CGEEKsO+asfCbgliAfEBDDrjZrWIpIg LNXSAKC0FABeY8SYUGUGONWSQKzsLpSoHwUIIQgGP3qSYlKEPOBCclUk0oD/pAqUu+NdAgfg8bRB DVMLAiLTUgEhJtISgo4wDGJjWt9gy9Bgn00zyJxseHIeeoQMYEYEIrBwRCJjdeUsLT4coPQB4QZE rT0hMFxLClW2LEgYc7ZJi6SDREuLBCX7EYAQc0YxSLy0hP2lICISY5Mn1D4UyQu41VDwjYXgq3K5 WtNCaS3gCJJxLXP0gQZaAg3iqR8hWDb14LQIJkjfIBAr9x96U/YJv25H8pxASBFz+YzQEaMtIhec KFktg1BAXBtl9CUHAHis4cfMf4RumO60wHE0qH9AoSOvxERI+rOspJwveI2kUK1bqRMzryDk0tX2 1uT8YQIM3MMQxrl+MLE6/y22HXABGmX8EAcaW1iAxg8/+KFtCS+KP98fOjKwVBTEWvC3HxgI3M6A wAo6SA1YB1oEF0TGBEE4rhbMk1UxOkCHYlTABgIgVgNqUAwgjC9fBliD+sqgBQa84B9xiJ8fGLA4 sf2BWCdwUjE4cDBamCBsrPmD8/DWCh/MCV1MAMNHfsWanWluENjSgnCO5o0GeGCHX/uDDIshQvTZ Tiiz+kEZ1kGCA7yhGCXQmz2w8IIH+iE69UrbKyDnmAooIwpgAIIPLvDAALxAEFCkRQMH4QFC3YgX BwAfO3L2hzT6AR64qkUbFjCHNqjQeHwAQBukYQB4YMgwL6SVN/bBOVpA5v9utDCeKwjQKIVogTN/ wM7HAmC2QQxhlQHY4x8OYINEYaAHSwgDi2D5lFleQGog0EMe7vADO3hMiH8QgQgMSYITtPIPJ1jl CXZWgwz8igEX6OUMVpnDV64Sma84ABPtYYE6HIQFSCjEBCAwgEjkkWsHSUQJfmmPAijgjgYxggza OYgNUIEIkjBkDuOZiBfsqgcfu0AGnskPIgxgAAswzSCqAIANSAKUfhAlQTf6iBhQAQBy2IEgihCD LlhUErzDwFLU8C1KjEEJHC1HERrkAg0YgRKyoU2sHMACSyzgATEtxwIAsAB+XuIBExjDHwZw0z/I IA2V2IEMglqOPDmgEET/uAFA/7ADFrQTBRGwKAUcoAKLDkAKI7iBCKwAgQXoxQUUEGkh2hmEQQxA AyqA6RdYoIERmHUCGjAEDiZw1T9cYQFSEMQVWuCGL2SPqpGwgldjAAC5TuEGSXBBXZ8QgyqIAQmZ 1UoEzLADHvxBChOYQBK8AIEnFOEPSKiCBgBQiCC44AEjGAASnCCCDUh2ACK4gQbcSgQZ0GACWF0A DVrwBytIAaJ/cMANIlCExD4gCZCFBHCnEBoXLIA5yLnBA6yAgxFEwAssAIAIiECEFlx1BC24AgBU MIEB0OC1G9gBFWQgghEUQgQLgEAMkiAHHnhhQWnggQi+UIUqqAECKmgB/w6gKggxQGC5ThhDDAbQ Av9CYALONQ0PYpDdR0zgpH8YAwCecAQq4OAII5CBGgaAnC4oAQcacAE7/dkCGUj3DyigbQtUoAII PGABLf1Dehcwgi5oQAZu9QIAHLDPIKgAqUigQI8L+wcNOGAKXqBBF9LgBAH/AQcRGE0QkAAApZaY ETgg8SCmoAIZOIEKfUXBFyJQhQVcAQI8WIBFR3AVJSSBBwNwwQ2U0IUFRGAAEQAqAIYmiAFcuAgu KEIakKACHkQ6wkXw6x8mIIUk1JcQQFtAfVkQgRg8wAEOQMIIlKACU1Ohrm9eRASsUIgN7EkMQBUE CuR6BD79wQnBFgFMnWzghGNTehBJHgAKuEuIIzRVDDHgAQ4qvQNc92wH/JQ2ta8gBkJooKe5VsQD aHAI4aYbEQ9AAQ808Nh3FyICezjEAG7QVHsPAgUsUJK/EeGCbSPiCwNPOCOMMGmFO1wSD4gATB9O 8Ypb/OLACAQAOw== ------=_NextPart_000_00D3_01CC0B12.32205B80 Content-Type: text/css; charset="iso-8859-2" Content-Transfer-Encoding: quoted-printable Content-Location: http://www.heidolph-instruments.co.uk/typo3temp/stylesheet_780afbcb2e.css .tx-indexedsearch .tx-indexedsearch-browsebox LI { DISPLAY: inline; MARGIN-RIGHT: 5px } .tx-indexedsearch .tx-indexedsearch-searchbox = INPUT.tx-indexedsearch-searchbox-button { WIDTH: 100px } .tx-indexedsearch .tx-indexedsearch-searchbox = INPUT.tx-indexedsearch-searchbox-sword { WIDTH: 150px } .tx-indexedsearch .tx-indexedsearch-whatis { MARGIN-TOP: 10px; MARGIN-BOTTOM: 5px } .tx-indexedsearch .tx-indexedsearch-whatis .tx-indexedsearch-sw { FONT-STYLE: italic; FONT-WEIGHT: bold } .tx-indexedsearch .tx-indexedsearch-noresults { TEXT-ALIGN: center; FONT-WEIGHT: bold } .tx-indexedsearch .tx-indexedsearch-res TD.tx-indexedsearch-descr { FONT-STYLE: italic } .tx-indexedsearch .tx-indexedsearch-res .tx-indexedsearch-descr = .tx-indexedsearch-redMarkup { COLOR: red } .tx-indexedsearch .tx-indexedsearch-res .tx-indexedsearch-info { BACKGROUND: #eeeeee } .tx-indexedsearch .tx-indexedsearch-res .tx-indexedsearch-secHead { MARGIN-TOP: 20px; MARGIN-BOTTOM: 5px } .tx-indexedsearch .tx-indexedsearch-res .tx-indexedsearch-secHead H2 { MARGIN-TOP: 0px; MARGIN-BOTTOM: 0px } .tx-indexedsearch .tx-indexedsearch-res .tx-indexedsearch-secHead TD { BACKGROUND: #cccccc; VERTICAL-ALIGN: middle } .tx-indexedsearch .tx-indexedsearch-res .noResume { COLOR: #666666 } .tx-indexedsearch .tx-indexedsearch-category { BACKGROUND: #cccccc; FONT-SIZE: 16px; FONT-WEIGHT: bold } .tx-indexedsearch .res-tmpl-css { MARGIN-BOTTOM: 1em; CLEAR: both } .tx-indexedsearch .searchbox-tmpl-css LABEL { WIDTH: 10em; FLOAT: left; MARGIN-RIGHT: 1em } .tx-indexedsearch .result-count-tmpl-css { MARGIN-TOP: -1.2em; FLOAT: right; LETTER-SPACING: 0px; FONT-WEIGHT: = normal } .tx-indexedsearch .percent-tmpl-css { MARGIN-TOP: -1.2em; FLOAT: right; LETTER-SPACING: 0px; FONT-WEIGHT: = normal } .tx-indexedsearch .info-tmpl-css DT { FLOAT: left } .tx-indexedsearch DL.info-tmpl-css DD { FLOAT: left } .tx-indexedsearch .info-tmpl-css DD.item-mtime { FLOAT: none } .tx-indexedsearch .info-tmpl-css DD.item-path { FLOAT: none } .tx-dropdownsitemap-pi1 UL { PADDING-BOTTOM: 0px; LIST-STYLE-TYPE: none; MARGIN: 0px; PADDING-LEFT: = 0px; PADDING-RIGHT: 0px; LIST-STYLE-IMAGE: none; PADDING-TOP: 0px } .tx-dropdownsitemap-pi1 OL { PADDING-BOTTOM: 0px; LIST-STYLE-TYPE: none; MARGIN: 0px; PADDING-LEFT: = 0px; PADDING-RIGHT: 0px; LIST-STYLE-IMAGE: none; PADDING-TOP: 0px } .tx-dropdownsitemap-pi1 A { BACKGROUND-COLOR: inherit; COLOR: #ff8700 } .tx-dropdownsitemap-pi1 A:link { BACKGROUND-COLOR: inherit; COLOR: #ff8700 } .tx-dropdownsitemap-pi1 A:visited { BACKGROUND-COLOR: inherit; COLOR: #ff8700 } .tx-dropdownsitemap-pi1 A:hover { BACKGROUND-COLOR: inherit; COLOR: #ff8700 } .tx-dropdownsitemap-pi1 A:active { BACKGROUND-COLOR: inherit; COLOR: #ff8700 } .tx-dropdownsitemap-pi1 DIV { PADDING-BOTTOM: 2px; MARGIN-TOP: 2px; PADDING-LEFT: 2px; PADDING-RIGHT: = 2px; MARGIN-LEFT: 20px; PADDING-TOP: 2px } .tx-dropdownsitemap-pi1 LI.open OL { DISPLAY: block } .tx-dropdownsitemap-pi1 LI.closed OL { DISPLAY: none } .tx-dropdownsitemap-pi1 LI.open UL { DISPLAY: block } .tx-dropdownsitemap-pi1 LI.closed UL { DISPLAY: none } .tx-dropdownsitemap-pi1 SPAN.ifsub { TEXT-TRANSFORM: uppercase; FONT-WEIGHT: bold } .tx-dropdownsitemap-pi1 SPAN.spc { TEXT-TRANSFORM: uppercase; FONT-STYLE: italic } .tx-dropdownsitemap-pi1 .description { FONT-STYLE: italic; MARGIN-LEFT: 5px; FONT-SIZE: 80% } .tx-dropdownsitemap-pi1 DIV { =09 } .tx-dropdownsitemap-pi1 DIV.level_2 { =09 } .tx-dropdownsitemap-pi1 DIV.level_3 { =09 } .tx-dropdownsitemap-pi1 DIV.level_4 { =09 } .tx-dropdownsitemap-pi1 DIV.level_5 { =09 } .tx-dropdownsitemap-pi1 DIV.expAll { BORDER-BOTTOM: #dba83b 1px solid; BORDER-LEFT: #dba83b 1px solid; = PADDING-BOTTOM: 5px; BACKGROUND-COLOR: #fcf2c8; PADDING-LEFT: 5px; = PADDING-RIGHT: 5px; COLOR: inherit; BORDER-TOP: #dba83b 1px solid; = BORDER-RIGHT: #dba83b 1px solid; PADDING-TOP: 5px } .tx-dropdownsitemap-pi1 IMG { MARGIN-RIGHT: 5px } .tx-t3consultancies-pi1 .tx-t3consultancies-pi1-listrow TD { PADDING-BOTTOM: 0px; BACKGROUND-COLOR: #eeeeee; PADDING-LEFT: 3px; = PADDING-RIGHT: 3px; PADDING-TOP: 0px } .tx-t3consultancies-pi1 .tx-t3consultancies-pi1-listrow = TR.tx-t3consultancies-pi1-listrow-header TD { BACKGROUND-COLOR: #cccccc } .tx-t3consultancies-pi1 .tx-t3consultancies-pi1-listrow = TR.tx-t3consultancies-pi1-listrow-header TD P { FONT-WEIGHT: bold } .tx-t3consultancies-pi1 .tx-t3consultancies-pi1-listrow = TR.tx-t3consultancies-pi1-listrow-odd TD { BACKGROUND-COLOR: #e0e0e0 } DIV.csc-textpic-caption-c .csc-textpic-caption { TEXT-ALIGN: center } DIV.csc-textpic-caption-r .csc-textpic-caption { TEXT-ALIGN: right } DIV.csc-textpic-caption-l .csc-textpic-caption { TEXT-ALIGN: left } DIV.csc-textpic DIV.csc-textpic-imagecolumn { DISPLAY: inline; FLOAT: left } DIV.csc-textpic-border DIV.csc-textpic-imagewrap .csc-textpic-image IMG = { BORDER-BOTTOM: #00427c 1px solid; BORDER-LEFT: #00427c 1px solid; = PADDING-BOTTOM: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; BORDER-TOP: = #00427c 1px solid; BORDER-RIGHT: #00427c 1px solid; PADDING-TOP: 0px } DIV.csc-textpic-imagewrap { PADDING-BOTTOM: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; = PADDING-TOP: 0px } DIV.csc-textpic IMG { BORDER-BOTTOM: medium none; BORDER-LEFT: medium none; BORDER-TOP: = medium none; BORDER-RIGHT: medium none } DIV.csc-textpic DIV.csc-textpic-imagewrap DIV.csc-textpic-image { FLOAT: left } DIV.csc-textpic DIV.csc-textpic-imagewrap UL { PADDING-BOTTOM: 0px; LIST-STYLE-TYPE: none; MARGIN: 0px; PADDING-LEFT: = 0px; PADDING-RIGHT: 0px; LIST-STYLE-IMAGE: none; PADDING-TOP: 0px } DIV.csc-textpic DIV.csc-textpic-imagewrap UL LI { PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: = 0px; FLOAT: left; PADDING-TOP: 0px } DIV.csc-textpic DIV.csc-textpic-imagewrap DL.csc-textpic-image { FLOAT: left } DIV.csc-textpic DIV.csc-textpic-imagewrap DL.csc-textpic-image DT { FLOAT: none } DIV.csc-textpic DIV.csc-textpic-imagewrap DL.csc-textpic-image DD { FLOAT: none } DIV.csc-textpic DIV.csc-textpic-imagewrap DL.csc-textpic-image DD IMG { BORDER-BOTTOM: medium none; BORDER-LEFT: medium none; BORDER-TOP: = medium none; BORDER-RIGHT: medium none } DL.csc-textpic-image { MARGIN: 0px } DL.csc-textpic-image DT { MARGIN: 0px; DISPLAY: inline } DL.csc-textpic-image DD { MARGIN: 0px } DIV.csc-textpic-clear { CLEAR: both } DIV.csc-textpic-left DIV.csc-textpic-imagewrap .csc-textpic-image { DISPLAY: inline; MARGIN-RIGHT: 10px } DIV.csc-textpic-intext-left-nowrap DIV.csc-textpic-imagewrap = .csc-textpic-image { DISPLAY: inline; MARGIN-RIGHT: 10px } DIV.csc-textpic-intext-left DIV.csc-textpic-imagewrap .csc-textpic-image = { DISPLAY: inline; MARGIN-RIGHT: 10px } DIV.csc-textpic-right DIV.csc-textpic-imagewrap .csc-textpic-image { DISPLAY: inline; MARGIN-LEFT: 10px } DIV.csc-textpic-intext-right-nowrap DIV.csc-textpic-imagewrap = .csc-textpic-image { DISPLAY: inline; MARGIN-LEFT: 10px } DIV.csc-textpic-intext-right DIV.csc-textpic-imagewrap = .csc-textpic-image { DISPLAY: inline; MARGIN-LEFT: 10px } DIV.csc-textpic-center DIV.csc-textpic-imagewrap .csc-textpic-image { DISPLAY: inline; MARGIN-LEFT: 10px } DIV.csc-textpic DIV.csc-textpic-imagewrap .csc-textpic-image = .csc-textpic-caption { MARGIN: 0px } DIV.csc-textpic DIV.csc-textpic-imagewrap .csc-textpic-image IMG { MARGIN: 0px } DIV.csc-textpic DIV.csc-textpic-imagewrap .csc-textpic-image { MARGIN-BOTTOM: 5px } DIV.csc-textpic-equalheight DIV.csc-textpic-imagerow { DISPLAY: block; MARGIN-BOTTOM: 5px } DIV.csc-textpic DIV.csc-textpic-imagerow { CLEAR: both } DIV.csc-textpic DIV.csc-textpic-imagewrap .csc-textpic-firstcol { MARGIN-LEFT: 0px !important } DIV.csc-textpic DIV.csc-textpic-imagewrap .csc-textpic-lastcol { MARGIN-RIGHT: 0px !important } DIV.csc-textpic-intext-left DIV.csc-textpic-imagewrap { MARGIN-RIGHT: 10px !important } DIV.csc-textpic-intext-left-nowrap DIV.csc-textpic-imagewrap { MARGIN-RIGHT: 10px !important } DIV.csc-textpic-intext-right DIV.csc-textpic-imagewrap { MARGIN-LEFT: 10px !important } DIV.csc-textpic-intext-right-nowrap DIV.csc-textpic-imagewrap { MARGIN-LEFT: 10px !important } DIV.csc-textpic-above DIV.csc-textpic-text { CLEAR: both } DIV.csc-textpic-center { TEXT-ALIGN: center } DIV.csc-textpic-center DIV.csc-textpic-imagewrap { MARGIN: 0px auto } DIV.csc-textpic-center DIV.csc-textpic-imagewrap .csc-textpic-image { TEXT-ALIGN: left } DIV.csc-textpic-center DIV.csc-textpic-text { TEXT-ALIGN: left } DIV.csc-textpic-right DIV.csc-textpic-imagewrap { FLOAT: right } DIV.csc-textpic-right DIV.csc-textpic-text { CLEAR: right } DIV.csc-textpic-left DIV.csc-textpic-imagewrap { FLOAT: left } DIV.csc-textpic-left DIV.csc-textpic-text { CLEAR: left } DIV.csc-textpic-intext-left DIV.csc-textpic-imagewrap { FLOAT: left } DIV.csc-textpic-intext-right DIV.csc-textpic-imagewrap { FLOAT: right } DIV.csc-textpic-intext-right-nowrap DIV.csc-textpic-imagewrap { FLOAT: right; CLEAR: both } * HTML DIV.csc-textpic-intext-right-nowrap .csc-textpic-text { HEIGHT: 1% } DIV.csc-textpic-intext-left-nowrap DIV.csc-textpic-imagewrap { FLOAT: left; CLEAR: both } * HTML DIV.csc-textpic-intext-left-nowrap .csc-textpic-text { HEIGHT: 1% } .csc-textpic-intext-left OL { PADDING-LEFT: 40px; HEIGHT: 1%; OVERFLOW: auto } .csc-textpic-intext-left UL { PADDING-LEFT: 40px; HEIGHT: 1%; OVERFLOW: auto } DIV.csc-textpic DIV.csc-textpic-imagerow-last { MARGIN-BOTTOM: 0px } ------=_NextPart_000_00D3_01CC0B12.32205B80 Content-Type: text/css; charset="iso-8859-2" Content-Transfer-Encoding: quoted-printable Content-Location: http://www.heidolph-instruments.co.uk/typo3conf/ext/wt_lightwindow/files/css/lightwindow.css #lightwindow_overlay { Z-INDEX: 500; POSITION: absolute; FILTER: alpha(opacity=3D0); = BACKGROUND-COLOR: white; WIDTH: 100%; DISPLAY: none; HEIGHT: 100px; = VISIBILITY: hidden; TOP: 0px; LEFT: 0px; -moz-opacity: 0.0; opacity: 0.0 } #lightwindow { Z-INDEX: 999; POSITION: absolute; LINE-HEIGHT: 0px; DISPLAY: none; = VISIBILITY: hidden } #lightwindow_container { POSITION: absolute; PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: = 0px; PADDING-RIGHT: 0px; DISPLAY: none; VISIBILITY: hidden; PADDING-TOP: = 0px } * HTML #lightwindow_container { OVERFLOW: hidden } #lightwindow_contents { Z-INDEX: 0; BORDER-BOTTOM: #ffffff 0px solid; POSITION: relative; = BORDER-LEFT: #ffffff 0px solid; OVERFLOW: hidden; BORDER-TOP: #ffffff = 0px solid; BORDER-RIGHT: #ffffff 0px solid } #lightwindow_loading { Z-INDEX: 9999; POSITION: absolute; PADDING-BOTTOM: 10px; = BACKGROUND-COLOR: #f0f0f0; PADDING-LEFT: 10px; WIDTH: 100%; = PADDING-RIGHT: 10px; HEIGHT: 100%; TOP: 0px; PADDING-TOP: 10px; LEFT: = 0px } #lightwindow_loading_shim { POSITION: absolute; WIDTH: 100%; DISPLAY: none; HEIGHT: 100%; TOP: 0px; = LEFT: 0px } #lightwindow_loading SPAN { PADDING-BOTTOM: 0px; LINE-HEIGHT: 32px; PADDING-LEFT: 0px; = PADDING-RIGHT: 10px; FLOAT: left; COLOR: #444444; FONT-SIZE: 12px; = PADDING-TOP: 0px } #lightwindow_loading SPAN A { COLOR: #09f; CURSOR: pointer; TEXT-DECORATION: none } #lightwindow_loading SPAN A:link { COLOR: #09f; CURSOR: pointer; TEXT-DECORATION: none } #lightwindow_loading SPAN A:visited { COLOR: #09f; CURSOR: pointer; TEXT-DECORATION: none } #lightwindow_loading SPAN A:hover { TEXT-DECORATION: underline } #lightwindow_loading SPAN A:active { TEXT-DECORATION: underline } #lightwindow_loading IMG { MARGIN: 0px; FLOAT: left } #lightwindow_navigation { POSITION: absolute; DISPLAY: none; TOP: 0px; LEFT: 0px } #lightwindow_navigation_shim { POSITION: absolute; WIDTH: 100%; DISPLAY: none; HEIGHT: 100%; TOP: 0px; = LEFT: 0px } #lightwindow_navigation A { OUTLINE-STYLE: none; OUTLINE-COLOR: invert; OUTLINE-WIDTH: medium } #lightwindow_navigation A:link { OUTLINE-STYLE: none; OUTLINE-COLOR: invert; OUTLINE-WIDTH: medium } #lightwindow_navigation A:visited { OUTLINE-STYLE: none; OUTLINE-COLOR: invert; OUTLINE-WIDTH: medium } #lightwindow_navigation A:hover { OUTLINE-STYLE: none; OUTLINE-COLOR: invert; OUTLINE-WIDTH: medium } #lightwindow_navigation A:active { OUTLINE-STYLE: none; OUTLINE-COLOR: invert; OUTLINE-WIDTH: medium } #lightwindow_previous { WIDTH: 49%; DISPLAY: block; BACKGROUND: url(../images/blank.gif) = no-repeat; HEIGHT: 100% } #lightwindow_next { WIDTH: 49%; DISPLAY: block; BACKGROUND: url(../images/blank.gif) = no-repeat; HEIGHT: 100% } #lightwindow_previous { FLOAT: left; LEFT: 0px } #lightwindow_next { FLOAT: right; RIGHT: 0px } #lightwindow_previous:hover { BACKGROUND: url(../images/prevlabel.gif) no-repeat left 15% } #lightwindow_previous:active { BACKGROUND: url(../images/prevlabel.gif) no-repeat left 15% } #lightwindow_next:hover { BACKGROUND: url(../images/nextlabel.gif) no-repeat right 15% } #lightwindow_next:active { BACKGROUND: url(../images/nextlabel.gif) no-repeat right 15% } #lightwindow_previous_title { DISPLAY: none } #lightwindow_next_title { DISPLAY: none } #lightwindow_galleries { Z-INDEX: 50; POSITION: absolute; MARGIN: 0px 0px 0px 10px; WIDTH: 100%; = BOTTOM: 0px; DISPLAY: none; OVERFLOW: hidden; LEFT: 0px } #lightwindow_galleries_tab_container { WIDTH: 100%; HEIGHT: 0px; OVERFLOW: hidden } A#lightwindow_galleries_tab { LINE-HEIGHT: 22px; WIDTH: 77px; DISPLAY: block; BACKGROUND: = url(../images/black-70.png) 0px 0px; FLOAT: right; HEIGHT: 20px; COLOR: = #ffffbe; FONT-SIZE: 11px; CURSOR: pointer; FONT-WEIGHT: bold; = TEXT-DECORATION: none } A#lightwindow_galleries_tab:link { LINE-HEIGHT: 22px; WIDTH: 77px; DISPLAY: block; BACKGROUND: = url(../images/black-70.png) 0px 0px; FLOAT: right; HEIGHT: 20px; COLOR: = #ffffbe; FONT-SIZE: 11px; CURSOR: pointer; FONT-WEIGHT: bold; = TEXT-DECORATION: none } A#lightwindow_galleries_tab:visited { LINE-HEIGHT: 22px; WIDTH: 77px; DISPLAY: block; BACKGROUND: = url(../images/black-70.png) 0px 0px; FLOAT: right; HEIGHT: 20px; COLOR: = #ffffbe; FONT-SIZE: 11px; CURSOR: pointer; FONT-WEIGHT: bold; = TEXT-DECORATION: none } * HTML A#lightwindow_galleries_tab { FILTER: alpha(opacity=3D70); BACKGROUND: #000000; opacity: .70 } * HTML A#lightwindow_galleries_tab:link { FILTER: alpha(opacity=3D70); BACKGROUND: #000000; opacity: .70 } * HTML A#lightwindow_galleries_tab:visited { FILTER: alpha(opacity=3D70); BACKGROUND: #000000; opacity: .70 } A#lightwindow_galleries_tab:hover { COLOR: #ffffbe } A#lightwindow_galleries_tab:active { COLOR: #ffffbe } #lightwindow_galleries_tab_span { PADDING-BOTTOM: 0px; PADDING-LEFT: 7px; WIDTH: 63px; PADDING-RIGHT: = 7px; DISPLAY: block; HEIGHT: 20px; PADDING-TOP: 0px } #lightwindow_galleries_tab .up { BACKGROUND: url(../images/arrow-up.gif) no-repeat 60px 5px } #lightwindow_galleries_tab .down { BACKGROUND: url(../images/arrow-down.gif) no-repeat 60px 6px } #lightwindow_galleries_list { BACKGROUND: url(../images/black-70.png) 0px 0px; HEIGHT: 0px; OVERFLOW: = hidden } * HTML #lightwindow_galleries_list { FILTER: alpha(opacity=3D70); BACKGROUND: none transparent scroll repeat = 0% 0%; opacity: .70 } .lightwindow_galleries_list { PADDING-BOTTOM: 10px; MARGIN: 0px 0px 10px; PADDING-LEFT: 10px; WIDTH: = 200px; PADDING-RIGHT: 10px; FLOAT: left; PADDING-TOP: 10px } .lightwindow_galleries_list H1 { PADDING-BOTTOM: 5px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; COLOR: = #09f; FONT-SIZE: 16px; CURSOR: pointer; FONT-WEIGHT: bold; = TEXT-DECORATION: none; PADDING-TOP: 10px } .lightwindow_galleries_list LI { LIST-STYLE-TYPE: none; MARGIN: 5px 0px } .lightwindow_galleries_list A { PADDING-BOTTOM: 0px; LINE-HEIGHT: 22px; PADDING-LEFT: 10px; = PADDING-RIGHT: 0px; DISPLAY: block; COLOR: #ffffff; FONT-SIZE: 11px; = CURSOR: pointer; FONT-WEIGHT: bold; TEXT-DECORATION: none; PADDING-TOP: = 0px } .lightwindow_galleries_list A:link { PADDING-BOTTOM: 0px; LINE-HEIGHT: 22px; PADDING-LEFT: 10px; = PADDING-RIGHT: 0px; DISPLAY: block; COLOR: #ffffff; FONT-SIZE: 11px; = CURSOR: pointer; FONT-WEIGHT: bold; TEXT-DECORATION: none; PADDING-TOP: = 0px } .lightwindow_galleries_list A:visited { PADDING-BOTTOM: 0px; LINE-HEIGHT: 22px; PADDING-LEFT: 10px; = PADDING-RIGHT: 0px; DISPLAY: block; COLOR: #ffffff; FONT-SIZE: 11px; = CURSOR: pointer; FONT-WEIGHT: bold; TEXT-DECORATION: none; PADDING-TOP: = 0px } .lightwindow_galleries_list A:hover { BORDER-LEFT: #ffffbe 3px solid; PADDING-BOTTOM: 0px; PADDING-LEFT: 7px; = PADDING-RIGHT: 0px; COLOR: #ffffbe; PADDING-TOP: 0px } .lightwindow_galleries_list A:active { BORDER-LEFT: #ffffbe 3px solid; PADDING-BOTTOM: 0px; PADDING-LEFT: 7px; = PADDING-RIGHT: 0px; COLOR: #ffffbe; PADDING-TOP: 0px } #lightwindow_data { POSITION: absolute } #lightwindow_data_slide { POSITION: relative } #lightwindow_data_slide_inner { PADDING-BOTTOM: 10px; BACKGROUND-COLOR: #ffffff; PADDING-LEFT: 10px; = PADDING-RIGHT: 10px; PADDING-TOP: 0px } #lightwindow_data_caption { PADDING-BOTTOM: 0px; LINE-HEIGHT: 25px; BACKGROUND-COLOR: #ffffff; = PADDING-LEFT: 0px; PADDING-RIGHT: 0px; COLOR: #666666; CLEAR: both; = PADDING-TOP: 10px } #lightwindow_data_details { PADDING-BOTTOM: 0px; BACKGROUND-COLOR: #f0f0f0; PADDING-LEFT: 10px; = PADDING-RIGHT: 10px; HEIGHT: 20px; PADDING-TOP: 0px } #lightwindow_data_author_container { TEXT-ALIGN: right; LINE-HEIGHT: 20px; FONT-STYLE: italic; WIDTH: 40%; = FLOAT: right; COLOR: #666666; FONT-SIZE: 10px; OVERFLOW: hidden } #lightwindow_data_gallery_container { TEXT-ALIGN: left; LINE-HEIGHT: 20px; WIDTH: 40%; FLOAT: left; COLOR: = #666666; FONT-SIZE: 10px; OVERFLOW: hidden } #lightwindow_title_bar { HEIGHT: 25px; OVERFLOW: hidden } #lightwindow_title_bar_title { TEXT-ALIGN: left; LINE-HEIGHT: 25px; FLOAT: left; COLOR: #444; = FONT-SIZE: 14px } A#lightwindow_title_bar_close_link { TEXT-ALIGN: right; PADDING-BOTTOM: 0px; LINE-HEIGHT: 25px; MARGIN: 0px = 50px 0px 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; FLOAT: right; = COLOR: #444; CURSOR: pointer; PADDING-TOP: 0px } A#lightwindow_title_bar_close_link:link { TEXT-ALIGN: right; PADDING-BOTTOM: 0px; LINE-HEIGHT: 25px; MARGIN: 0px = 50px 0px 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; FLOAT: right; = COLOR: #444; CURSOR: pointer; PADDING-TOP: 0px } A#lightwindow_title_bar_close_link:visited { TEXT-ALIGN: right; PADDING-BOTTOM: 0px; LINE-HEIGHT: 25px; MARGIN: 0px = 50px 0px 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; FLOAT: right; = COLOR: #444; CURSOR: pointer; PADDING-TOP: 0px } A#lightwindow_title_bar_close_link:hover { COLOR: #ffffff } A#lightwindow_title_bar_close_link:active { COLOR: #ffffff } #lightwindow P { PADDING-RIGHT: 10px; COLOR: #000000 } ------=_NextPart_000_00D3_01CC0B12.32205B80 Content-Type: text/css; charset="iso-8859-2" Content-Transfer-Encoding: quoted-printable Content-Location: http://www.heidolph-instruments.co.uk/fileadmin/templates/style.css BODY { TEXT-ALIGN: center; PADDING-BOTTOM: 0px; LINE-HEIGHT: 16px; OVERFLOW-X: = hidden; MARGIN: 0px auto; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; = FONT-FAMILY: Arial, Helvetica, Verdana, sans-serif; BACKGROUND: = url(img/back.png) #e1e1e1 repeat-x 50% top; COLOR: #222; FONT-SIZE: = 12px; PADDING-TOP: 0px } TABLE { LINE-HEIGHT: 16px; FONT-FAMILY: Arial, Helvetica, Verdana, sans-serif; = COLOR: #222; FONT-SIZE: 12px; VERTICAL-ALIGN: top } TD { LINE-HEIGHT: 16px; FONT-FAMILY: Arial, Helvetica, Verdana, sans-serif; = COLOR: #222; FONT-SIZE: 12px; VERTICAL-ALIGN: top } H1 { PADDING-BOTTOM: 0px; LINE-HEIGHT: 20px; MARGIN: 0px; PADDING-LEFT: 0px; = PADDING-RIGHT: 0px; COLOR: #666; FONT-SIZE: 14px; PADDING-TOP: 0px } H1.merkzettel { DISPLAY: none; FLOAT: right } H2 { PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: = 0px; COLOR: #222; FONT-SIZE: 12px; PADDING-TOP: 0px } H3 { PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: = 0px; COLOR: #222; FONT-SIZE: 12px; PADDING-TOP: 0px } H4 { PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: = 0px; COLOR: #222; FONT-SIZE: 12px; PADDING-TOP: 0px } H5 { PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: = 0px; COLOR: #222; FONT-SIZE: 12px; PADDING-TOP: 0px } #teaser H1 { PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: = 0px; COLOR: #222; FONT-SIZE: 12px; PADDING-TOP: 0px } H5 { COLOR: #222; FONT-SIZE: 14px; FONT-WEIGHT: bold } HR { BORDER-BOTTOM: 0px; BORDER-LEFT: 0px; MARGIN: 10px 0px 5px; HEIGHT: = 1px; CLEAR: both; BORDER-TOP: #222 1px solid; BORDER-RIGHT: 0px } HR.noclear { CLEAR: none } HR.blue { MARGIN: 0px 0px 5px; BORDER-TOP: #0046ad 1px dotted } HR.orange { MARGIN: 0px 0px 5px; BORDER-TOP: #e7601c 1px solid } FIELDSET { BORDER-BOTTOM: 0px; BORDER-LEFT: 0px; PADDING-BOTTOM: 0px !important; = MARGIN: 0px; PADDING-LEFT: 0px !important; PADDING-RIGHT: 0px = !important; BORDER-TOP: 0px; BORDER-RIGHT: 0px; PADDING-TOP: 0px = !important } LEGEND { BORDER-BOTTOM: 0px; BORDER-LEFT: 0px; PADDING-BOTTOM: 0px !important; = MARGIN: 0px; PADDING-LEFT: 0px !important; PADDING-RIGHT: 0px = !important; BORDER-TOP: 0px; BORDER-RIGHT: 0px; PADDING-TOP: 0px = !important } LEGEND { DISPLAY: none } LABEL { PADDING-BOTTOM: 0px; LINE-HEIGHT: 12px; MARGIN: 0px; PADDING-LEFT: 0px; = WIDTH: 100px; PADDING-RIGHT: 0px; FLOAT: left; PADDING-TOP: 2px = !important } INPUT.csc-mailform-submit { WIDTH: 75px !important; MARGIN-LEFT: 100px } .csc-mailform INPUT { PADDING-BOTTOM: 1px; PADDING-LEFT: 2px; WIDTH: 270px; PADDING-RIGHT: = 2px; PADDING-TOP: 1px } .csc-mailform TEXTAREA { PADDING-BOTTOM: 1px; PADDING-LEFT: 2px; WIDTH: 270px; PADDING-RIGHT: = 2px; PADDING-TOP: 1px } .csc-mailform-field { MARGIN-BOTTOM: 5px; CLEAR: both } .csc-mailform-radio { MARGIN-TOP: -7px; MARGIN-BOTTOM: 10px; FLOAT: left; MARGIN-LEFT: 0px } .csc-mailform-radio LABEL { MARGIN-TOP: -8px; WIDTH: 100px; MARGIN-BOTTOM: 14px; MARGIN-LEFT: 5px } .csc-mailform-radio LEGEND { VISIBILITY: hidden } #inhalt .tx-felogin-pi1 FORM { BORDER-BOTTOM: 0px; BORDER-LEFT: #d5e4ec 1px solid; PADDING-BOTTOM: = 15px; MARGIN-TOP: 10px; PADDING-LEFT: 10px; WIDTH: 325px; PADDING-RIGHT: = 10px; MARGIN-BOTTOM: -10px; BORDER-TOP: #d5e4ec 1px solid; BORDER-RIGHT: = #d5e4ec 1px solid; PADDING-TOP: 15px } INPUT { BORDER-BOTTOM: #666 1px solid; BORDER-LEFT: #666 1px solid; = BACKGROUND-COLOR: #fff; FONT-FAMILY: Arial, Helvetica, Verdana, = sans-serif; COLOR: #666; FONT-SIZE: 11px; BORDER-TOP: #666 1px solid; = BORDER-RIGHT: #666 1px solid } TEXTAREA { BORDER-BOTTOM: #666 1px solid; BORDER-LEFT: #666 1px solid; = BACKGROUND-COLOR: #fff; FONT-FAMILY: Arial, Helvetica, Verdana, = sans-serif; COLOR: #666; FONT-SIZE: 11px; BORDER-TOP: #666 1px solid; = BORDER-RIGHT: #666 1px solid } SELECT { BORDER-BOTTOM: #666 1px solid; BORDER-LEFT: #666 1px solid; = BACKGROUND-COLOR: #fff; FONT-FAMILY: Arial, Helvetica, Verdana, = sans-serif; COLOR: #666; FONT-SIZE: 11px; BORDER-TOP: #666 1px solid; = BORDER-RIGHT: #666 1px solid } INPUT:focus { BACKGROUND-COLOR: #f7f7f7 } TEXTAREA:focus { BACKGROUND-COLOR: #f7f7f7 } INPUT:hover { BACKGROUND-COLOR: #f7f7f7 } TEXTAREA:hover { BACKGROUND-COLOR: #f7f7f7 } A:link { COLOR: #0046ad; TEXT-DECORATION: none } A:active { COLOR: #0046ad; TEXT-DECORATION: none } A:visited { COLOR: #0046ad; TEXT-DECORATION: none } A:hover { TEXT-DECORATION: underline } A.merkzettel { MARGIN: -1px 5px 0px 0px; FLOAT: left } #master { BORDER-BOTTOM: transparent 1px solid; POSITION: relative; TEXT-ALIGN: = left; BORDER-LEFT: transparent 1px solid; MARGIN: -1px auto 0px; = MIN-HEIGHT: 680px; WIDTH: 998px; BACKGROUND: url(img/glasflaschen.jpg) = no-repeat; BORDER-TOP: transparent 1px solid; BORDER-RIGHT: transparent = 1px solid } * HTML #master { PADDING-BOTTOM: 0px } #header { POSITION: absolute; WIDTH: 998px; DISPLAY: none; BACKGROUND-REPEAT: = no-repeat; HEIGHT: 80px; TOP: 0px; LEFT: 0px } #logo { POSITION: absolute; WIDTH: 170px; HEIGHT: 54px; TOP: 18px; LEFT: 22px } #lang { POSITION: absolute; HEIGHT: 13px; TOP: 6px; RIGHT: 0px } #lang IMG { MARGIN-LEFT: 8px } #menue { POSITION: absolute; WIDTH: 585px; HEIGHT: 23px; TOP: 50px; LEFT: 235px } #imprint { POSITION: absolute; WIDTH: 585px; HEIGHT: 23px; TOP: 50px; LEFT: 235px } #imprint { WIDTH: 145px; DISPLAY: none; LEFT: 845px } #menue UL { LIST-STYLE-POSITION: outside; PADDING-BOTTOM: 0px; LIST-STYLE-TYPE: = none; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; DISPLAY: = inline; PADDING-TOP: 0px } #menue LI { LIST-STYLE-POSITION: outside; PADDING-BOTTOM: 0px; LIST-STYLE-TYPE: = none; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; DISPLAY: = inline; PADDING-TOP: 0px } #imprint UL { LIST-STYLE-POSITION: outside; PADDING-BOTTOM: 0px; LIST-STYLE-TYPE: = none; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; DISPLAY: = inline; PADDING-TOP: 0px } #imprint LI { LIST-STYLE-POSITION: outside; PADDING-BOTTOM: 0px; LIST-STYLE-TYPE: = none; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; DISPLAY: = inline; PADDING-TOP: 0px } #menue A:link { BORDER-LEFT: #aaa 1px solid; PADDING-BOTTOM: 0px; PADDING-LEFT: 9px; = PADDING-RIGHT: 9px; HEIGHT: 12px; COLOR: #666; TEXT-DECORATION: none; = PADDING-TOP: 0px } #menue A:active { BORDER-LEFT: #aaa 1px solid; PADDING-BOTTOM: 0px; PADDING-LEFT: 9px; = PADDING-RIGHT: 9px; HEIGHT: 12px; COLOR: #666; TEXT-DECORATION: none; = PADDING-TOP: 0px } #menue A:visited { BORDER-LEFT: #aaa 1px solid; PADDING-BOTTOM: 0px; PADDING-LEFT: 9px; = PADDING-RIGHT: 9px; HEIGHT: 12px; COLOR: #666; TEXT-DECORATION: none; = PADDING-TOP: 0px } #imprint A:link { BORDER-LEFT: #aaa 1px solid; PADDING-BOTTOM: 0px; PADDING-LEFT: 9px; = PADDING-RIGHT: 9px; HEIGHT: 12px; COLOR: #666; TEXT-DECORATION: none; = PADDING-TOP: 0px } #imprint A:active { BORDER-LEFT: #aaa 1px solid; PADDING-BOTTOM: 0px; PADDING-LEFT: 9px; = PADDING-RIGHT: 9px; HEIGHT: 12px; COLOR: #666; TEXT-DECORATION: none; = PADDING-TOP: 0px } #imprint A:visited { BORDER-LEFT: #aaa 1px solid; PADDING-BOTTOM: 0px; PADDING-LEFT: 9px; = PADDING-RIGHT: 9px; HEIGHT: 12px; COLOR: #666; TEXT-DECORATION: none; = PADDING-TOP: 0px } #menue A:hover { COLOR: #0046ad } #imprint A:hover { COLOR: #0046ad } #menue .cur A:link { COLOR: #0046ad; FONT-WEIGHT: bold } #menue .cur A:active { COLOR: #0046ad; FONT-WEIGHT: bold } #menue .cur A:visited { COLOR: #0046ad; FONT-WEIGHT: bold } #menue .cur A:hover { COLOR: #0046ad; FONT-WEIGHT: bold } #imprint .cur A:link { COLOR: #0046ad; FONT-WEIGHT: bold } #imprint .cur A:active { COLOR: #0046ad; FONT-WEIGHT: bold } #imprint .cur A:visited { COLOR: #0046ad; FONT-WEIGHT: bold } #imprint .cur A:hover { COLOR: #0046ad; FONT-WEIGHT: bold } #menue .last { =09 } #inccon { MARGIN-TOP: 85px; DISPLAY: block } #left { Z-INDEX: 7; POSITION: relative; WIDTH: 180px; FLOAT: left; TOP: 30px; = LEFT: 0px } #submenu { POSITION: relative; WIDTH: 180px; LEFT: 0px } #submenu UL { LIST-STYLE-POSITION: outside; PADDING-BOTTOM: 0px; LIST-STYLE-TYPE: = none; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; PADDING-TOP: = 0px } #submenu LI { LIST-STYLE-POSITION: outside; PADDING-BOTTOM: 0px; LIST-STYLE-TYPE: = none; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; PADDING-TOP: = 0px } #submenu UL.levelone { =09 } #submenu LI.levelone { BACKGROUND: url(img/submenu.png) repeat-x } #submenu .levelone A:link { PADDING-BOTTOM: 3px; PADDING-LEFT: 25px; WIDTH: 165px; PADDING-RIGHT: = 0px; DISPLAY: block; BACKGROUND: url(img/submenu.png) no-repeat; COLOR: = #0046ad; TEXT-DECORATION: none; PADDING-TOP: 2px } #submenu .levelone A:active { PADDING-BOTTOM: 3px; PADDING-LEFT: 25px; WIDTH: 165px; PADDING-RIGHT: = 0px; DISPLAY: block; BACKGROUND: url(img/submenu.png) no-repeat; COLOR: = #0046ad; TEXT-DECORATION: none; PADDING-TOP: 2px } #submenu .levelone A:visited { PADDING-BOTTOM: 3px; PADDING-LEFT: 25px; WIDTH: 165px; PADDING-RIGHT: = 0px; DISPLAY: block; BACKGROUND: url(img/submenu.png) no-repeat; COLOR: = #0046ad; TEXT-DECORATION: none; PADDING-TOP: 2px } #submenu .levelone A:hover { TEXT-DECORATION: underline } #submenu .cur A:link { PADDING-BOTTOM: 3px; PADDING-LEFT: 25px; PADDING-RIGHT: 0px; = BACKGROUND: url(img/submenu_c.png) no-repeat; COLOR: #fff; BORDER-TOP: = #fff 1px solid; FONT-WEIGHT: bold; PADDING-TOP: 2px } #submenu .cur A:active { PADDING-BOTTOM: 3px; PADDING-LEFT: 25px; PADDING-RIGHT: 0px; = BACKGROUND: url(img/submenu_c.png) no-repeat; COLOR: #fff; BORDER-TOP: = #fff 1px solid; FONT-WEIGHT: bold; PADDING-TOP: 2px } #submenu .cur A:visited { PADDING-BOTTOM: 3px; PADDING-LEFT: 25px; PADDING-RIGHT: 0px; = BACKGROUND: url(img/submenu_c.png) no-repeat; COLOR: #fff; BORDER-TOP: = #fff 1px solid; FONT-WEIGHT: bold; PADDING-TOP: 2px } #submenu .cur A:hover { PADDING-BOTTOM: 3px; PADDING-LEFT: 25px; PADDING-RIGHT: 0px; = BACKGROUND: url(img/submenu_c.png) no-repeat; COLOR: #fff; BORDER-TOP: = #fff 1px solid; FONT-WEIGHT: bold; PADDING-TOP: 2px } #submenu .cursub A:link { PADDING-BOTTOM: 7px; PADDING-LEFT: 25px; PADDING-RIGHT: 0px; = BACKGROUND: url(img/submenu_a.png) no-repeat; COLOR: #fff; BORDER-TOP: = #fff 1px solid; FONT-WEIGHT: bold; PADDING-TOP: 7px } #submenu .cursub A:active { PADDING-BOTTOM: 7px; PADDING-LEFT: 25px; PADDING-RIGHT: 0px; = BACKGROUND: url(img/submenu_a.png) no-repeat; COLOR: #fff; BORDER-TOP: = #fff 1px solid; FONT-WEIGHT: bold; PADDING-TOP: 7px } #submenu .cursub A:visited { PADDING-BOTTOM: 7px; PADDING-LEFT: 25px; PADDING-RIGHT: 0px; = BACKGROUND: url(img/submenu_a.png) no-repeat; COLOR: #fff; BORDER-TOP: = #fff 1px solid; FONT-WEIGHT: bold; PADDING-TOP: 7px } #submenu .cursub A:hover { PADDING-BOTTOM: 7px; PADDING-LEFT: 25px; PADDING-RIGHT: 0px; = BACKGROUND: url(img/submenu_a.png) no-repeat; COLOR: #fff; BORDER-TOP: = #fff 1px solid; FONT-WEIGHT: bold; PADDING-TOP: 7px } #submenu UL .leveltwo { =09 } #submenu .leveltwo LI { =09 } #submenu .noborder { =09 } #submenu .leveltwo A:link { BORDER-BOTTOM: 0px; BORDER-LEFT: 0px; PADDING-BOTTOM: 3px; LINE-HEIGHT: = 13px; PADDING-LEFT: 12px; WIDTH: 168px; PADDING-RIGHT: 0px; DISPLAY: = block; BACKGROUND: none transparent scroll repeat 0% 0%; COLOR: #222; = FONT-SIZE: 11px; BORDER-TOP: 0px; BORDER-RIGHT: 0px; TEXT-DECORATION: = none; PADDING-TOP: 2px } #submenu .leveltwo A:active { BORDER-BOTTOM: 0px; BORDER-LEFT: 0px; PADDING-BOTTOM: 3px; LINE-HEIGHT: = 13px; PADDING-LEFT: 12px; WIDTH: 168px; PADDING-RIGHT: 0px; DISPLAY: = block; BACKGROUND: none transparent scroll repeat 0% 0%; COLOR: #222; = FONT-SIZE: 11px; BORDER-TOP: 0px; BORDER-RIGHT: 0px; TEXT-DECORATION: = none; PADDING-TOP: 2px } #submenu .leveltwo A:visited { BORDER-BOTTOM: 0px; BORDER-LEFT: 0px; PADDING-BOTTOM: 3px; LINE-HEIGHT: = 13px; PADDING-LEFT: 12px; WIDTH: 168px; PADDING-RIGHT: 0px; DISPLAY: = block; BACKGROUND: none transparent scroll repeat 0% 0%; COLOR: #222; = FONT-SIZE: 11px; BORDER-TOP: 0px; BORDER-RIGHT: 0px; TEXT-DECORATION: = none; PADDING-TOP: 2px } #submenu .leveltwo A:hover { TEXT-DECORATION: underline } #submenu .cur2 A:link { BACKGROUND: url(img/arrow2_cur.gif) #cfd0d2 no-repeat right 5px; = FONT-WEIGHT: bold } #submenu .cur2 A:active { BACKGROUND: url(img/arrow2_cur.gif) #cfd0d2 no-repeat right 5px; = FONT-WEIGHT: bold } #submenu .cur2 A:visited { BACKGROUND: url(img/arrow2_cur.gif) #cfd0d2 no-repeat right 5px; = FONT-WEIGHT: bold } #submenu .cur2 A:hover { BACKGROUND: url(img/arrow2_cur.gif) #cfd0d2 no-repeat right 5px; = FONT-WEIGHT: bold } #submenu .act2 A:link { BACKGROUND: none transparent scroll repeat 0% 0%; FONT-WEIGHT: bold } #submenu .act2 A:active { BACKGROUND: none transparent scroll repeat 0% 0%; FONT-WEIGHT: bold } #submenu .act2 A:visited { BACKGROUND: none transparent scroll repeat 0% 0%; FONT-WEIGHT: bold } #submenu .act2 A:hover { BACKGROUND: none transparent scroll repeat 0% 0%; FONT-WEIGHT: bold } #submenu .levelthree A:link { BORDER-BOTTOM: 0px; BORDER-LEFT: 0px; PADDING-BOTTOM: 3px; = PADDING-LEFT: 22px; WIDTH: 158px; PADDING-RIGHT: 0px; DISPLAY: block; = BACKGROUND: none transparent scroll repeat 0% 0%; COLOR: #222; = BORDER-TOP: 0px; BORDER-RIGHT: 0px; TEXT-DECORATION: none; PADDING-TOP: = 2px } #submenu .levelthree A:active { BORDER-BOTTOM: 0px; BORDER-LEFT: 0px; PADDING-BOTTOM: 3px; = PADDING-LEFT: 22px; WIDTH: 158px; PADDING-RIGHT: 0px; DISPLAY: block; = BACKGROUND: none transparent scroll repeat 0% 0%; COLOR: #222; = BORDER-TOP: 0px; BORDER-RIGHT: 0px; TEXT-DECORATION: none; PADDING-TOP: = 2px } #submenu .levelthree A:visited { BORDER-BOTTOM: 0px; BORDER-LEFT: 0px; PADDING-BOTTOM: 3px; = PADDING-LEFT: 22px; WIDTH: 158px; PADDING-RIGHT: 0px; DISPLAY: block; = BACKGROUND: none transparent scroll repeat 0% 0%; COLOR: #222; = BORDER-TOP: 0px; BORDER-RIGHT: 0px; TEXT-DECORATION: none; PADDING-TOP: = 2px } #submenu .levelthree A:hover { TEXT-DECORATION: underline } #submenu .cur3 A:link { BACKGROUND: url(img/arrow2_cur.gif) #cfd0d2 no-repeat right 5px; = FONT-WEIGHT: bold } #submenu .cur3 A:active { BACKGROUND: url(img/arrow2_cur.gif) #cfd0d2 no-repeat right 5px; = FONT-WEIGHT: bold } #submenu .cur3 A:visited { BACKGROUND: url(img/arrow2_cur.gif) #cfd0d2 no-repeat right 5px; = FONT-WEIGHT: bold } #submenu .cur3 A:hover { BACKGROUND: url(img/arrow2_cur.gif) #cfd0d2 no-repeat right 5px; = FONT-WEIGHT: bold } #submenu .act3 A:link { BACKGROUND: none transparent scroll repeat 0% 0%; FONT-WEIGHT: bold } #submenu .act3 A:active { BACKGROUND: none transparent scroll repeat 0% 0%; FONT-WEIGHT: bold } #submenu .act3 A:visited { BACKGROUND: none transparent scroll repeat 0% 0%; FONT-WEIGHT: bold } #submenu .act3 A:hover { BACKGROUND: none transparent scroll repeat 0% 0%; FONT-WEIGHT: bold } #submenu .levelfour A:link { BORDER-BOTTOM: 0px; BORDER-LEFT: 0px; PADDING-BOTTOM: 3px; = PADDING-LEFT: 32px; WIDTH: 148px; PADDING-RIGHT: 0px; DISPLAY: block; = BACKGROUND: none transparent scroll repeat 0% 0%; COLOR: #222; = BORDER-TOP: 0px; BORDER-RIGHT: 0px; TEXT-DECORATION: none; PADDING-TOP: = 2px } #submenu .levelfour A:active { BORDER-BOTTOM: 0px; BORDER-LEFT: 0px; PADDING-BOTTOM: 3px; = PADDING-LEFT: 32px; WIDTH: 148px; PADDING-RIGHT: 0px; DISPLAY: block; = BACKGROUND: none transparent scroll repeat 0% 0%; COLOR: #222; = BORDER-TOP: 0px; BORDER-RIGHT: 0px; TEXT-DECORATION: none; PADDING-TOP: = 2px } #submenu .levelfour A:visited { BORDER-BOTTOM: 0px; BORDER-LEFT: 0px; PADDING-BOTTOM: 3px; = PADDING-LEFT: 32px; WIDTH: 148px; PADDING-RIGHT: 0px; DISPLAY: block; = BACKGROUND: none transparent scroll repeat 0% 0%; COLOR: #222; = BORDER-TOP: 0px; BORDER-RIGHT: 0px; TEXT-DECORATION: none; PADDING-TOP: = 2px } #submenu .levelfour A:hover { TEXT-DECORATION: underline } #submenu .cur4 A:link { BACKGROUND: url(img/arrow2_cur.gif) #cfd0d2 no-repeat right 5px; = FONT-WEIGHT: bold } #submenu .cur4 A:active { BACKGROUND: url(img/arrow2_cur.gif) #cfd0d2 no-repeat right 5px; = FONT-WEIGHT: bold } #submenu .cur4 A:visited { BACKGROUND: url(img/arrow2_cur.gif) #cfd0d2 no-repeat right 5px; = FONT-WEIGHT: bold } #submenu .cur4 A:hover { BACKGROUND: url(img/arrow2_cur.gif) #cfd0d2 no-repeat right 5px; = FONT-WEIGHT: bold } #submenu .act4 A:link { BACKGROUND: none transparent scroll repeat 0% 0%; FONT-WEIGHT: bold } #submenu .act4 A:active { BACKGROUND: none transparent scroll repeat 0% 0%; FONT-WEIGHT: bold } #submenu .act4 A:visited { BACKGROUND: none transparent scroll repeat 0% 0%; FONT-WEIGHT: bold } #submenu .act4 A:hover { BACKGROUND: none transparent scroll repeat 0% 0%; FONT-WEIGHT: bold } #submenu .levelfive A:link { BORDER-BOTTOM: 0px; BORDER-LEFT: 0px; PADDING-BOTTOM: 3px; = PADDING-LEFT: 42px; WIDTH: 138px; PADDING-RIGHT: 0px; DISPLAY: block; = BACKGROUND: none transparent scroll repeat 0% 0%; COLOR: #222; = BORDER-TOP: 0px; BORDER-RIGHT: 0px; TEXT-DECORATION: none; PADDING-TOP: = 2px } #submenu .levelfive A:active { BORDER-BOTTOM: 0px; BORDER-LEFT: 0px; PADDING-BOTTOM: 3px; = PADDING-LEFT: 42px; WIDTH: 138px; PADDING-RIGHT: 0px; DISPLAY: block; = BACKGROUND: none transparent scroll repeat 0% 0%; COLOR: #222; = BORDER-TOP: 0px; BORDER-RIGHT: 0px; TEXT-DECORATION: none; PADDING-TOP: = 2px } #submenu .levelfive A:visited { BORDER-BOTTOM: 0px; BORDER-LEFT: 0px; PADDING-BOTTOM: 3px; = PADDING-LEFT: 42px; WIDTH: 138px; PADDING-RIGHT: 0px; DISPLAY: block; = BACKGROUND: none transparent scroll repeat 0% 0%; COLOR: #222; = BORDER-TOP: 0px; BORDER-RIGHT: 0px; TEXT-DECORATION: none; PADDING-TOP: = 2px } #submenu .levelfive A:hover { TEXT-DECORATION: underline } #submenu .cur5 A:link { BACKGROUND: url(img/arrow2_cur.gif) #cfd0d2 no-repeat right 5px; = FONT-WEIGHT: bold } #submenu .cur5 A:active { BACKGROUND: url(img/arrow2_cur.gif) #cfd0d2 no-repeat right 5px; = FONT-WEIGHT: bold } #submenu .cur5 A:visited { BACKGROUND: url(img/arrow2_cur.gif) #cfd0d2 no-repeat right 5px; = FONT-WEIGHT: bold } #submenu .cur5 A:hover { BACKGROUND: url(img/arrow2_cur.gif) #cfd0d2 no-repeat right 5px; = FONT-WEIGHT: bold } #submenu .border A:link { =09 } #submenu .border A:active { =09 } #submenu .border A:visited { =09 } #submenu .border { =09 } #boxes { MARGIN-TOP: 30px } #boxes H1 { PADDING-BOTTOM: 0px; PADDING-LEFT: 28px; WIDTH: 152px; PADDING-RIGHT: = 0px; BACKGROUND: url(img/boxes.png) no-repeat; HEIGHT: 24px; COLOR: = #fff; FONT-SIZE: 12px; PADDING-TOP: 6px } #boxes FORM { PADDING-BOTTOM: 10px; MARGIN: -1px 0px 10px; PADDING-LEFT: 10px; = PADDING-RIGHT: 10px; BACKGROUND: #ccc; PADDING-TOP: 10px } #boxes SELECT { WIDTH: 160px; MARGIN-BOTTOM: 5px } #search { MARGIN-TOP: 10px } #search .tx-indexedsearch-searchbox-sword { BORDER-BOTTOM: #aaa 1px solid; BORDER-LEFT: #aaa 1px solid; = PADDING-BOTTOM: 1px; PADDING-LEFT: 3px; WIDTH: 110px; PADDING-RIGHT: = 3px; HEIGHT: 14px; VERTICAL-ALIGN: middle; BORDER-TOP: #aaa 1px solid; = BORDER-RIGHT: #aaa 1px solid; PADDING-TOP: 1px } #search .submit { BORDER-BOTTOM: #0046ad 2px solid; BORDER-LEFT: 0px; BACKGROUND: = #0046ad; HEIGHT: 18px; COLOR: #fff; VERTICAL-ALIGN: middle; BORDER-TOP: = 0px; BORDER-RIGHT: 0px } #right { POSITION: relative; WIDTH: 800px; FLOAT: right; TOP: 0px; RIGHT: 2px } #freecall { Z-INDEX: 11; POSITION: absolute; PADDING-BOTTOM: 0px; PADDING-LEFT: = 10px; PADDING-RIGHT: 10px; BACKGROUND: #0046ad; COLOR: #fff; FONT-SIZE: = 14px; TOP: 37px; RIGHT: 1px; FONT-WEIGHT: bold; PADDING-TOP: 0px } #subsubmenu { Z-INDEX: 10; POSITION: relative; WIDTH: 800px; MARGIN-BOTTOM: -30px; = BACKGROUND: #fff; HEIGHT: 30px; TOP: 0px; LEFT: 0px } #subsubmenu UL { LIST-STYLE-POSITION: outside; PADDING-BOTTOM: 0px; LIST-STYLE-TYPE: = none; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; DISPLAY: = inline; PADDING-TOP: 0px } #subsubmenu LI { LIST-STYLE-POSITION: outside; PADDING-BOTTOM: 0px; LIST-STYLE-TYPE: = none; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; DISPLAY: = inline; PADDING-TOP: 0px } #subsubmenu UL { MARGIN-LEFT: 0px } #subsubmenu UL.levelone { =09 } #subsubmenu A:link { TEXT-ALIGN: center; PADDING-BOTTOM: 0px; LINE-HEIGHT: 11px; = PADDING-LEFT: 5px; WIDTH: 149px; PADDING-RIGHT: 5px; DISPLAY: block; = BACKGROUND: url(img/tab.png) no-repeat; FLOAT: left; HEIGHT: 25px; = COLOR: #666; FONT-SIZE: 11px; MARGIN-RIGHT: 1px; TEXT-DECORATION: none; = PADDING-TOP: 5px } #subsubmenu A:active { TEXT-ALIGN: center; PADDING-BOTTOM: 0px; LINE-HEIGHT: 11px; = PADDING-LEFT: 5px; WIDTH: 149px; PADDING-RIGHT: 5px; DISPLAY: block; = BACKGROUND: url(img/tab.png) no-repeat; FLOAT: left; HEIGHT: 25px; = COLOR: #666; FONT-SIZE: 11px; MARGIN-RIGHT: 1px; TEXT-DECORATION: none; = PADDING-TOP: 5px } #subsubmenu A:visited { TEXT-ALIGN: center; PADDING-BOTTOM: 0px; LINE-HEIGHT: 11px; = PADDING-LEFT: 5px; WIDTH: 149px; PADDING-RIGHT: 5px; DISPLAY: block; = BACKGROUND: url(img/tab.png) no-repeat; FLOAT: left; HEIGHT: 25px; = COLOR: #666; FONT-SIZE: 11px; MARGIN-RIGHT: 1px; TEXT-DECORATION: none; = PADDING-TOP: 5px } #subsubmenu A:hover { TEXT-DECORATION: underline } #subsubmenu .cur A:link { BACKGROUND: url(img/tab_a.png) no-repeat; COLOR: #fff; FONT-WEIGHT: = bold } #subsubmenu .cur A:active { BACKGROUND: url(img/tab_a.png) no-repeat; COLOR: #fff; FONT-WEIGHT: = bold } #subsubmenu .cur A:visited { BACKGROUND: url(img/tab_a.png) no-repeat; COLOR: #fff; FONT-WEIGHT: = bold } #subsubmenu .cur A:hover { BACKGROUND: url(img/tab_a.png) no-repeat; COLOR: #fff; FONT-WEIGHT: = bold } #subsubmenu H1 { PADDING-BOTTOM: 5px; MARGIN: 0px; PADDING-LEFT: 10px; PADDING-RIGHT: = 10px; PADDING-TOP: 5px } #inhalt { BORDER-BOTTOM: 0px; POSITION: relative; BORDER-LEFT: #ccc 1px solid; = PADDING-BOTTOM: 20px; MARGIN: 29px 0px 0px; MIN-HEIGHT: 650px; = PADDING-LEFT: 10px; WIDTH: 778px; PADDING-RIGHT: 10px; BACKGROUND: #fff; = BORDER-TOP: #ccc 1px solid; BORDER-RIGHT: #ccc 1px solid; PADDING-TOP: = 0px } #inhalt H1 { BORDER-BOTTOM: #e7601c 3px solid; PADDING-BOTTOM: 5px; MARGIN: 0px = -11px; PADDING-LEFT: 10px; PADDING-RIGHT: 10px; BACKGROUND: #0046ad; = HEIGHT: 20px !important; COLOR: #fff; PADDING-TOP: 5px } #inhaltToTop { BORDER-BOTTOM: #e7601c 3px solid; PADDING-BOTTOM: 5px; MARGIN: 0px = -11px; PADDING-LEFT: 10px; PADDING-RIGHT: 10px; BACKGROUND: #0046ad; = HEIGHT: 20px !important; COLOR: #fff; PADDING-TOP: 5px } #inhaltToTop A:link { COLOR: #fff } #inhaltToTop A:active { COLOR: #fff } #inhaltToTop A:visited { COLOR: #fff } #inhaltToTop { TEXT-ALIGN: right; PADDING-RIGHT: 15px; HEIGHT: 16px } #inhalt OBJECT { MARGIN: 0px -10px } #inhalt UL { =09 } #inhalt LI { =09 } #inhalt LI { MARGIN-LEFT: -25px } #roundedcorners { BORDER-BOTTOM: red 0px solid; POSITION: relative; BORDER-LEFT: red 0px = solid; WIDTH: 799px; BACKGROUND: url(img/inhalt.png) no-repeat; HEIGHT: = 13px; BORDER-TOP: red 0px solid; BORDER-RIGHT: red 0px solid } #clearer { CLEAR: both } #footer { PADDING-BOTTOM: 15px; PADDING-LEFT: 270px; WIDTH: 726px; PADDING-RIGHT: = 0px; DISPLAY: none; BACKGROUND: url(img/inccon.gif) #fff repeat-y; = FONT-SIZE: 10px; PADDING-TOP: 0px } #footer UL { MARGIN: -16px 0px 20px 220px } #footer UL { LIST-STYLE-POSITION: outside; TEXT-ALIGN: center; PADDING-BOTTOM: 0px; = LIST-STYLE-TYPE: none; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; DISPLAY: = inline; FLOAT: left; PADDING-TOP: 0px } #footer LI { LIST-STYLE-POSITION: outside; TEXT-ALIGN: center; PADDING-BOTTOM: 0px; = LIST-STYLE-TYPE: none; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; DISPLAY: = inline; FLOAT: left; PADDING-TOP: 0px } #footer A:link { MARGIN: 0px 5px; COLOR: #acacac; FONT-SIZE: 10px; TEXT-DECORATION: = underline } #footer A:active { MARGIN: 0px 5px; COLOR: #acacac; FONT-SIZE: 10px; TEXT-DECORATION: = underline } #footer A:visited { MARGIN: 0px 5px; COLOR: #acacac; FONT-SIZE: 10px; TEXT-DECORATION: = underline } #footer A:hover { TEXT-DECORATION: none } #footer .cur { FONT-WEIGHT: bold } .bodytext { PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: = 0px; PADDING-TOP: 0px } P { PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: = 0px; PADDING-TOP: 0px } .align-center { TEXT-ALIGN: center } .align-right { TEXT-ALIGN: right } .tx-kiwislider-pi1 .bodytext { PADDING-BOTTOM: 0px; PADDING-LEFT: 10px; PADDING-RIGHT: 10px; = PADDING-TOP: 0px } .tx-kiwislider-pi1 .csc-textpic-intext-left-nowrap { PADDING-BOTTOM: 0px; PADDING-LEFT: 10px; PADDING-RIGHT: 10px; = PADDING-TOP: 0px } .tx-kiwislider-pi1 .csc-textpic-left { PADDING-BOTTOM: 0px; PADDING-LEFT: 10px; PADDING-RIGHT: 10px; = PADDING-TOP: 0px } .contenttable { =09 } .contenttable TD { PADDING-BOTTOM: 1px; PADDING-LEFT: 5px; PADDING-RIGHT: 5px; = PADDING-TOP: 1px } .tr-even { =09 } .tr-odd { =09 } .upload { MARGIN: 5px 0px } .upload IMG { VERTICAL-ALIGN: top; MARGIN-RIGHT: 0px } .uploadIcon { FLOAT: left; HEIGHT: 20px } .uploadSize { PADDING-LEFT: 10px } .internal-link IMG { BORDER-BOTTOM: 0px; BORDER-LEFT: 0px; BORDER-TOP: 0px; BORDER-RIGHT: = 0px } .csc-textpic-caption { PADDING-BOTTOM: 6px; FONT-STYLE: italic !important; FONT-SIZE: 14px; = FONT-WEIGHT: bold; PADDING-TOP: 5px } TABLE.kolben .td-0 { WIDTH: 160px } TABLE.kolben .td-1 { WIDTH: 80px } TABLE.kolben .td-2 { WIDTH: 100px } .conmerkzettel { =09 } DIV.csc-textpic-clear { CLEAR: none } .upload A IMG { MARGIN-RIGHT: 5px } #inhaltZweispaltig { POSITION: relative } #inhaltZweispaltigLinks { WIDTH: 48%; FLOAT: left } #inhaltZweispaltigRechts { WIDTH: 48%; FLOAT: right } #inhaltZweispaltigClear { CLEAR: both } #inhaltZweispaltig3070 { POSITION: relative } #inhaltZweispaltig3070Links { WIDTH: 28%; FLOAT: left } #inhaltZweispaltig3070Rechts { WIDTH: 68%; FLOAT: right } #inhaltZweispaltig3070Clear { CLEAR: both } #inhaltDreispaltig { POSITION: relative; MARGIN: 0px -11px } #inhaltDreispaltigLinks { BORDER-BOTTOM: transparent 1px solid; POSITION: relative; BORDER-LEFT: = transparent 1px solid; WIDTH: 32%; FLOAT: left; BORDER-TOP: transparent = 1px solid; BORDER-RIGHT: transparent 1px solid } #inhaltDreispaltigRechts { BORDER-BOTTOM: transparent 1px solid; POSITION: relative; BORDER-LEFT: = transparent 1px solid; WIDTH: 32%; FLOAT: right; BORDER-TOP: transparent = 1px solid; BORDER-RIGHT: transparent 1px solid } #inhaltDreispaltigMitte { BORDER-BOTTOM: transparent 1px solid; POSITION: relative; BORDER-LEFT: = transparent 1px solid; WIDTH: 32%; MARGIN-LEFT: 34%; BORDER-TOP: = transparent 1px solid; BORDER-RIGHT: transparent 1px solid } #inhaltDreispaltigMitte DIV.csc-textpic-center DIV.csc-textpic-text { CLEAR: none } #inhaltDreispaltigClear { CLEAR: both } #inhaltDreispaltig H1 { BORDER-BOTTOM: 0px; MARGIN: 0px; BACKGROUND: url(img/h1.png) no-repeat } #inhaltDreispaltig H1 A { COLOR: #fff } #inhaltDreispaltig P A { PADDING-RIGHT: 12px; BACKGROUND: url(img/arrow.png) no-repeat right 4px } #inhaltDreispaltig253535 { POSITION: relative; CLEAR: both } #inhaltDreispaltig253535Links { BORDER-BOTTOM: transparent 1px solid; POSITION: relative; BORDER-LEFT: = transparent 1px solid; WIDTH: 20%; FLOAT: left; BORDER-TOP: transparent = 1px solid; BORDER-RIGHT: transparent 1px solid } #inhaltDreispaltig253535Rechts { BORDER-BOTTOM: transparent 1px solid; POSITION: relative; BORDER-LEFT: = transparent 1px solid; WIDTH: 38%; FLOAT: right; BORDER-TOP: transparent = 1px solid; BORDER-RIGHT: transparent 1px solid } #inhaltDreispaltig253535Mitte { BORDER-BOTTOM: transparent 1px solid; POSITION: relative; BORDER-LEFT: = transparent 1px solid; WIDTH: 38%; MARGIN-LEFT: 21%; BORDER-TOP: = transparent 1px solid; BORDER-RIGHT: transparent 1px solid } #inhaltDreispaltig253535Mitte DIV.csc-textpic-center = DIV.csc-textpic-text { CLEAR: none } #inhaltDreispaltigClear { CLEAR: both } #inhaltDreispaltig253535 H1 { BORDER-BOTTOM: 0px; MARGIN: 0px; BACKGROUND: url(img/h1.png) no-repeat } #inhaltDreispaltig253535 H1 A { COLOR: #fff } #inhaltDreispaltig253535 P A { PADDING-RIGHT: 12px; BACKGROUND: url(img/arrow.png) no-repeat right 4px } #inhaltCatalog { MARGIN-BOTTOM: 25px; CLEAR: right } #inhaltCatalog A { TEXT-ALIGN: center; WIDTH: 160px; BACKGROUND: url(img/catalog.gif) = no-repeat; FLOAT: right; HEIGHT: 22px; COLOR: #fff; PADDING-TOP: 3px } #inhaltCatalog A:hover { FONT-WEIGHT: bold; TEXT-DECORATION: none } #inhalt .csc-sitemap { POSITION: relative; TEXT-ALIGN: left; WIDTH: auto; TEXT-DECORATION: = none; LEFT: -15px } #inhalt .csc-sitemap UL { TEXT-ALIGN: left; LIST-STYLE-TYPE: none; COLOR: #72777a; = TEXT-DECORATION: none } #inhalt .csc-sitemap UL LI { BORDER-BOTTOM: #6b6c70 1px solid; PADDING-BOTTOM: 10px; COLOR: #72777a; = TEXT-DECORATION: none; PADDING-TOP: 5px } #inhalt .csc-sitemap UL LI A:link { COLOR: #72777a; TEXT-DECORATION: none } #inhalt .csc-sitemap UL LI A:active { COLOR: #72777a; TEXT-DECORATION: none } #inhalt .csc-sitemap UL LI A:visited { COLOR: #72777a; TEXT-DECORATION: none } #inhalt .csc-sitemap UL LI A:hover { COLOR: #72777a; TEXT-DECORATION: underline } #inhalt .csc-sitemap UL UL LI { BORDER-BOTTOM-STYLE: none; PADDING-BOTTOM: 0px; BORDER-RIGHT-STYLE: = none; PADDING-LEFT: 15px; PADDING-RIGHT: 0px; BORDER-TOP-STYLE: none; = COLOR: #72777a; BORDER-LEFT-STYLE: none; FONT-WEIGHT: normal; = TEXT-DECORATION: none; PADDING-TOP: 0px } #inhalt .csc-sitemap UL UL LI A:link { COLOR: #72777a; FONT-WEIGHT: normal; TEXT-DECORATION: none } #inhalt .csc-sitemap UL UL LI A:active { COLOR: #72777a; FONT-WEIGHT: normal; TEXT-DECORATION: none } #inhalt .csc-sitemap UL UL LI A:visited { COLOR: #72777a; FONT-WEIGHT: normal; TEXT-DECORATION: none } #inhalt .csc-sitemap UL UL LI A:hover { COLOR: #72777a; FONT-WEIGHT: normal; TEXT-DECORATION: underline } DIV.csc-textpic-right DIV.csc-textpic-imagewrap { FLOAT: left } DIV.csc-textpic-right DIV.csc-textpic-text { CLEAR: none } DIV.csc-textpic-left DIV.csc-textpic-imagewrap { FLOAT: left; CLEAR: none } DIV.csc-textpic-left DIV.csc-textpic-text { PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: = 0px; CLEAR: none; PADDING-TOP: 0px } DIV.csc-textpic-below DIV.csc-textpic-imagewrap { FLOAT: left } DIV.csc-textpic-below DIV.csc-textpic-text { CLEAR: none } #teaser DIV.csc-textpic DIV.csc-textpic-imagewrap .csc-textpic-image { MARGIN: 0px } #teaser DIV.csc-textpic-center DIV.csc-textpic-imagewrap = .csc-textpic-image { MARGIN: 0px } DIV.csc-textpic-intext-left-nowrap DIV.csc-textpic-imagewrap { CLEAR: none } DIV.csc-textpic IMG { MARGIN-TOP: 3px !important } #inhaltDreispaltig .csc-textpic-image { WIDTH: 256px !important } .merkzettelHeader { FONT-WEIGHT: bold } .merkzettelBodytext { MARGIN-LEFT: 21px } .merkzettelClear { MARGIN-BOTTOM: 7px; CLEAR: both } .tx-products-pi1 .item { WIDTH: 260px; FLOAT: left; HEIGHT: 170px; MARGIN-RIGHT: 20px } .tx-products-pi1 .image { FLOAT: left; MARGIN-RIGHT: 10px } #lightwindow_iframe { BACKGROUND: #fff; -moz-opacity: .85; opacity: .75 } .tx-t3consultancies-pi1 .tx-t3consultancies-pi1-modeSelector { TEXT-ALIGN: center } #fancy_title_main { PADDING-TOP: 8px } .tx-indexedsearch UL.browsebox { MARGIN-LEFT: -10px } .tx-indexedsearch .browsebox LI { PADDING-BOTTOM: 0px; PADDING-LEFT: 15px; PADDING-RIGHT: 15px; = PADDING-TOP: 0px } ------=_NextPart_000_00D3_01CC0B12.32205B80 Content-Type: text/css; charset="iso-8859-2" Content-Transfer-Encoding: 7bit Content-Location: http://www.heidolph-instruments.co.uk/fileadmin/templates/style_products.css .scrollContainer #rahmen1 IMG { MARGIN: -5px -10px 0px; WIDTH: 799px !important } #inhalt #rahmen1 IMG { MARGIN: -5px -10px 0px; WIDTH: 799px !important } * HTML #inhalt #rahmen1 IMG { MARGIN: 0px; WIDTH: 799px !important } * HTML #inhalt { PADDING-LEFT: 0px; WIDTH: 798px; PADDING-RIGHT: 0px } * HTML #inhalt P { PADDING-LEFT: 10px; PADDING-RIGHT: 10px } * HTML #inhalt H4 { PADDING-LEFT: 10px; PADDING-RIGHT: 10px } #inhalt { PADDING-BOTTOM: 0px; MIN-HEIGHT: 500px; MARGIN-BOTTOM: -5px } * HTML #inhalt { HEIGHT: 500px !important } * HTML #inhalt H1 { PADDING-LEFT: 22px !important; PADDING-RIGHT: 22px !important } * HTML #inhalt #inhaltDreispaltig H1 { PADDING-LEFT: 11px !important } #layerWechsel { POSITION: absolute; MARGIN-TOP: 33px; DISPLAY: none } #layerWechsel IMG { MARGIN: 0px; WIDTH: 100% !important; HEIGHT: 100% !important } #inhalt #rahmen1 #layerWechsel IMG { MARGIN: 0px; WIDTH: 100% !important; HEIGHT: 100% !important } #layerWechsel A { OUTLINE-STYLE: none; OUTLINE-COLOR: invert; OUTLINE-WIDTH: medium } ------=_NextPart_000_00D3_01CC0B12.32205B80 Content-Type: text/css; charset="iso-8859-2" Content-Transfer-Encoding: 7bit Content-Location: http://www.heidolph-instruments.co.uk/fileadmin/templates/styleIE8.css .tx_distributors { MARGIN: 0px } ------=_NextPart_000_00D3_01CC0B12.32205B80 Content-Type: text/css; charset="iso-8859-2" Content-Transfer-Encoding: quoted-printable Content-Location: http://www.heidolph-instruments.co.uk/typo3conf/ext/jq_fancybox/fancybox/css/fancy.css DIV#fancy_overlay { Z-INDEX: 90; POSITION: absolute; BACKGROUND-COLOR: #333; WIDTH: 100%; = TOP: 0px; LEFT: 0px } DIV#fancy_loading { Z-INDEX: 100; POSITION: absolute; WIDTH: 40px; DISPLAY: none; = BACKGROUND: none transparent scroll repeat 0% 0%; HEIGHT: 40px; = OVERFLOW: hidden; CURSOR: pointer } DIV#fancy_loading DIV { POSITION: absolute; WIDTH: 40px; BACKGROUND: = url(../images/fancy_progress.png) no-repeat; HEIGHT: 480px; TOP: 0px; = LEFT: 0px } DIV#fancy_close { Z-INDEX: 100; POSITION: absolute; WIDTH: 30px; DISPLAY: none; = BACKGROUND: url(../images/fancy_closebox.png); HEIGHT: 30px; TOP: -12px; = CURSOR: pointer; RIGHT: -12px } * HTML DIV#fancy_close { BACKGROUND: url(../images/fancy_closebox.gif) } DIV#fancy_content { Z-INDEX: 96; POSITION: absolute; PADDING-BOTTOM: 0px; MARGIN: 0px; = PADDING-LEFT: 0px; WIDTH: 100%; PADDING-RIGHT: 0px; HEIGHT: 100%; TOP: = 0px; PADDING-TOP: 0px; LEFT: 0px } #fancy_frame { POSITION: relative; WIDTH: 100%; DISPLAY: none; HEIGHT: 100% } IMG#fancy_img { Z-INDEX: 92; BORDER-BOTTOM: 0px; POSITION: absolute; BORDER-LEFT: 0px; = PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; WIDTH: 100%; = PADDING-RIGHT: 0px; HEIGHT: 100%; BORDER-TOP: 0px; TOP: 0px; = BORDER-RIGHT: 0px; PADDING-TOP: 0px; LEFT: 0px } DIV#fancy_title { Z-INDEX: 100; POSITION: absolute; WIDTH: 100%; BOTTOM: -35px; DISPLAY: = none; LEFT: 0px } DIV#fancy_title TABLE { MARGIN: 0px auto } DIV#fancy_title DIV { PADDING-BOTTOM: 2px; FONT: bold 12px Arial; COLOR: #fff } TD#fancy_title_left { WIDTH: 15px; BACKGROUND: url(../images/fancy_title_left.png) repeat-x; = HEIGHT: 32px } TD#fancy_title_main { BACKGROUND: url(../images/fancy_title_main.png) repeat-x; HEIGHT: 32px } TD#fancy_title_right { WIDTH: 15px; BACKGROUND: url(../images/fancy_title_right.png) repeat-x; = HEIGHT: 32px } DIV#fancy_outer { Z-INDEX: 999; POSITION: absolute; PADDING-BOTTOM: 58px; MARGIN: 0px; = PADDING-LEFT: 18px; PADDING-RIGHT: 18px; DISPLAY: none; BACKGROUND: none = transparent scroll repeat 0% 0%; OVERFLOW: hidden; TOP: 0px; = PADDING-TOP: 18px; LEFT: 0px } DIV#fancy_inner { BORDER-BOTTOM: #444 1px solid; POSITION: relative; BORDER-LEFT: #444 = 1px solid; WIDTH: 100%; BACKGROUND: #fff; HEIGHT: 100%; BORDER-TOP: #444 = 1px solid; BORDER-RIGHT: #444 1px solid } A#fancy_left { BACKGROUND-IMAGE: url(data:image/gif;base64,AAAA); Z-INDEX: 100; = POSITION: absolute; WIDTH: 35%; BOTTOM: 10px; HEIGHT: 100%; CURSOR: = pointer } A#fancy_right { BACKGROUND-IMAGE: url(data:image/gif;base64,AAAA); Z-INDEX: 100; = POSITION: absolute; WIDTH: 35%; BOTTOM: 10px; HEIGHT: 100%; CURSOR: = pointer } A#fancy_left { LEFT: 0px } A#fancy_right { RIGHT: 0px } A#fancy_left:hover { BACKGROUND: url(../images/fancy_left.gif) no-repeat 0% 100% } A#fancy_right:hover { BACKGROUND: url(../images/fancy_right.gif) no-repeat 100% 100% } #fancy_bigIframe { Z-INDEX: 10; POSITION: absolute; WIDTH: 100%; HEIGHT: 100%; TOP: 0px; = LEFT: 0px } #fancy_freeIframe { Z-INDEX: 10; POSITION: absolute; WIDTH: 100%; HEIGHT: 100%; TOP: 0px; = LEFT: 0px } DIV#fancy_bg { DISPLAY: none } DIV.fancy_bg { Z-INDEX: 70; POSITION: absolute; DISPLAY: block } DIV.fancy_bg_n { WIDTH: 100%; BACKGROUND: url(../images/fancy_shadow_n.png) repeat-x; = HEIGHT: 18px; TOP: -18px } DIV.fancy_bg_ne { WIDTH: 13px; BACKGROUND: url(../images/fancy_shadow_ne.png) no-repeat; = HEIGHT: 18px; TOP: -18px; RIGHT: -13px } DIV.fancy_bg_e { WIDTH: 13px; BACKGROUND: url(../images/fancy_shadow_e.png) repeat-y; = HEIGHT: 100%; RIGHT: -13px } DIV.fancy_bg_se { WIDTH: 13px; BOTTOM: -18px; BACKGROUND: = url(../images/fancy_shadow_se.png) no-repeat; HEIGHT: 18px; RIGHT: -13px } DIV.fancy_bg_s { WIDTH: 100%; BOTTOM: -18px; BACKGROUND: = url(../images/fancy_shadow_s.png) repeat-x; HEIGHT: 18px } DIV.fancy_bg_sw { WIDTH: 13px; BOTTOM: -18px; BACKGROUND: = url(../images/fancy_shadow_sw.png) no-repeat; HEIGHT: 18px; LEFT: -13px } DIV.fancy_bg_w { WIDTH: 13px; BACKGROUND: url(../images/fancy_shadow_w.png) repeat-y; = HEIGHT: 100%; LEFT: -13px } DIV.fancy_bg_nw { WIDTH: 13px; BACKGROUND: url(../images/fancy_shadow_nw.png) no-repeat; = HEIGHT: 18px; TOP: -18px; LEFT: -13px } ------=_NextPart_000_00D3_01CC0B12.32205B80 Content-Type: application/octet-stream Content-Transfer-Encoding: quoted-printable Content-Location: http://www.heidolph-instruments.co.uk/fileadmin/templates/smoothscroll.js /* Smooth scrolling=0A= Changes links that link to other parts of this page to scroll=0A= smoothly to those links rather than jump to them directly, which=0A= can be a little disorienting.=0A= =0A= sil, http://www.kryogenix.org/=0A= =0A= v1.0 2003-11-11=0A= v1.1 2005-06-16 wrap it up in an object=0A= */=0A= =0A= var ss =3D {=0A= fixAllLinks: function() {=0A= // Get a list of all links in the page=0A= var allLinks =3D document.getElementsByTagName('a');=0A= // Walk through the list=0A= for (var i=3D0;i tag corresponding to this href=0A= // First strip off the hash (first character)=0A= anchor =3D target.hash.substr(1);=0A= // Now loop all A tags until we find one with that name=0A= var allLinks =3D document.getElementsByTagName('a');=0A= var destinationLink =3D null;=0A= for (var i=3D0;i -1,=0A= WebKit: navigator.userAgent.indexOf('AppleWebKit/') > -1,=0A= Gecko: navigator.userAgent.indexOf('Gecko') > -1 &&=0A= navigator.userAgent.indexOf('KHTML') =3D=3D=3D -1,=0A= MobileSafari: !!navigator.userAgent.match(/Apple.*Mobile.*Safari/)=0A= },=0A= =0A= BrowserFeatures: {=0A= XPath: !!document.evaluate,=0A= SelectorsAPI: !!document.querySelector,=0A= ElementExtensions: !!window.HTMLElement,=0A= SpecificElementExtensions:=0A= document.createElement('div')['__proto__'] &&=0A= document.createElement('div')['__proto__'] !=3D=3D=0A= document.createElement('form')['__proto__']=0A= },=0A= =0A= ScriptFragment: ']*>([\\S\\s]*?)<\/script>',=0A= JSONFilter: /^\/\*-secure-([\s\S]*)\*\/\s*$/,=0A= =0A= emptyFunction: function() { },=0A= K: function(x) { return x }=0A= };=0A= =0A= if (Prototype.Browser.MobileSafari)=0A= Prototype.BrowserFeatures.SpecificElementExtensions =3D false;=0A= =0A= =0A= /* Based on Alex Arnell's inheritance implementation. */=0A= var Class =3D {=0A= create: function() {=0A= var parent =3D null, properties =3D $A(arguments);=0A= if (Object.isFunction(properties[0]))=0A= parent =3D properties.shift();=0A= =0A= function klass() {=0A= this.initialize.apply(this, arguments);=0A= }=0A= =0A= Object.extend(klass, Class.Methods);=0A= klass.superclass =3D parent;=0A= klass.subclasses =3D [];=0A= =0A= if (parent) {=0A= var subclass =3D function() { };=0A= subclass.prototype =3D parent.prototype;=0A= klass.prototype =3D new subclass;=0A= parent.subclasses.push(klass);=0A= }=0A= =0A= for (var i =3D 0; i < properties.length; i++)=0A= klass.addMethods(properties[i]);=0A= =0A= if (!klass.prototype.initialize)=0A= klass.prototype.initialize =3D Prototype.emptyFunction;=0A= =0A= klass.prototype.constructor =3D klass;=0A= =0A= return klass;=0A= }=0A= };=0A= =0A= Class.Methods =3D {=0A= addMethods: function(source) {=0A= var ancestor =3D this.superclass && this.superclass.prototype;=0A= var properties =3D Object.keys(source);=0A= =0A= if (!Object.keys({ toString: true }).length)=0A= properties.push("toString", "valueOf");=0A= =0A= for (var i =3D 0, length =3D properties.length; i < length; i++) {=0A= var property =3D properties[i], value =3D source[property];=0A= if (ancestor && Object.isFunction(value) &&=0A= value.argumentNames().first() =3D=3D "$super") {=0A= var method =3D value;=0A= value =3D (function(m) {=0A= return function() { return ancestor[m].apply(this, arguments) = };=0A= })(property).wrap(method);=0A= =0A= value.valueOf =3D method.valueOf.bind(method);=0A= value.toString =3D method.toString.bind(method);=0A= }=0A= this.prototype[property] =3D value;=0A= }=0A= =0A= return this;=0A= }=0A= };=0A= =0A= var Abstract =3D { };=0A= =0A= Object.extend =3D function(destination, source) {=0A= for (var property in source)=0A= destination[property] =3D source[property];=0A= return destination;=0A= };=0A= =0A= Object.extend(Object, {=0A= inspect: function(object) {=0A= try {=0A= if (Object.isUndefined(object)) return 'undefined';=0A= if (object =3D=3D=3D null) return 'null';=0A= return object.inspect ? object.inspect() : String(object);=0A= } catch (e) {=0A= if (e instanceof RangeError) return '...';=0A= throw e;=0A= }=0A= },=0A= =0A= toJSON: function(object) {=0A= var type =3D typeof object;=0A= switch (type) {=0A= case 'undefined':=0A= case 'function':=0A= case 'unknown': return;=0A= case 'boolean': return object.toString();=0A= }=0A= =0A= if (object =3D=3D=3D null) return 'null';=0A= if (object.toJSON) return object.toJSON();=0A= if (Object.isElement(object)) return;=0A= =0A= var results =3D [];=0A= for (var property in object) {=0A= var value =3D Object.toJSON(object[property]);=0A= if (!Object.isUndefined(value))=0A= results.push(property.toJSON() + ': ' + value);=0A= }=0A= =0A= return '{' + results.join(', ') + '}';=0A= },=0A= =0A= toQueryString: function(object) {=0A= return $H(object).toQueryString();=0A= },=0A= =0A= toHTML: function(object) {=0A= return object && object.toHTML ? object.toHTML() : = String.interpret(object);=0A= },=0A= =0A= keys: function(object) {=0A= var keys =3D [];=0A= for (var property in object)=0A= keys.push(property);=0A= return keys;=0A= },=0A= =0A= values: function(object) {=0A= var values =3D [];=0A= for (var property in object)=0A= values.push(object[property]);=0A= return values;=0A= },=0A= =0A= clone: function(object) {=0A= return Object.extend({ }, object);=0A= },=0A= =0A= isElement: function(object) {=0A= return !!(object && object.nodeType =3D=3D 1);=0A= },=0A= =0A= isArray: function(object) {=0A= return object !=3D null && typeof object =3D=3D "object" &&=0A= 'splice' in object && 'join' in object;=0A= },=0A= =0A= isHash: function(object) {=0A= return object instanceof Hash;=0A= },=0A= =0A= isFunction: function(object) {=0A= return typeof object =3D=3D "function";=0A= },=0A= =0A= isString: function(object) {=0A= return typeof object =3D=3D "string";=0A= },=0A= =0A= isNumber: function(object) {=0A= return typeof object =3D=3D "number";=0A= },=0A= =0A= isUndefined: function(object) {=0A= return typeof object =3D=3D "undefined";=0A= }=0A= });=0A= =0A= Object.extend(Function.prototype, {=0A= argumentNames: function() {=0A= var names =3D = this.toString().match(/^[\s\(]*function[^(]*\(([^\)]*)\)/)[1]=0A= .replace(/\s+/g, '').split(',');=0A= return names.length =3D=3D 1 && !names[0] ? [] : names;=0A= },=0A= =0A= bind: function() {=0A= if (arguments.length < 2 && Object.isUndefined(arguments[0])) return = this;=0A= var __method =3D this, args =3D $A(arguments), object =3D = args.shift();=0A= return function() {=0A= return __method.apply(object, args.concat($A(arguments)));=0A= }=0A= },=0A= =0A= bindAsEventListener: function() {=0A= var __method =3D this, args =3D $A(arguments), object =3D = args.shift();=0A= return function(event) {=0A= return __method.apply(object, [event || = window.event].concat(args));=0A= }=0A= },=0A= =0A= curry: function() {=0A= if (!arguments.length) return this;=0A= var __method =3D this, args =3D $A(arguments);=0A= return function() {=0A= return __method.apply(this, args.concat($A(arguments)));=0A= }=0A= },=0A= =0A= delay: function() {=0A= var __method =3D this, args =3D $A(arguments), timeout =3D = args.shift() * 1000;=0A= return window.setTimeout(function() {=0A= return __method.apply(__method, args);=0A= }, timeout);=0A= },=0A= =0A= defer: function() {=0A= var args =3D [0.01].concat($A(arguments));=0A= return this.delay.apply(this, args);=0A= },=0A= =0A= wrap: function(wrapper) {=0A= var __method =3D this;=0A= return function() {=0A= return wrapper.apply(this, = [__method.bind(this)].concat($A(arguments)));=0A= }=0A= },=0A= =0A= methodize: function() {=0A= if (this._methodized) return this._methodized;=0A= var __method =3D this;=0A= return this._methodized =3D function() {=0A= return __method.apply(null, [this].concat($A(arguments)));=0A= };=0A= }=0A= });=0A= =0A= Date.prototype.toJSON =3D function() {=0A= return '"' + this.getUTCFullYear() + '-' +=0A= (this.getUTCMonth() + 1).toPaddedString(2) + '-' +=0A= this.getUTCDate().toPaddedString(2) + 'T' +=0A= this.getUTCHours().toPaddedString(2) + ':' +=0A= this.getUTCMinutes().toPaddedString(2) + ':' +=0A= this.getUTCSeconds().toPaddedString(2) + 'Z"';=0A= };=0A= =0A= var Try =3D {=0A= these: function() {=0A= var returnValue;=0A= =0A= for (var i =3D 0, length =3D arguments.length; i < length; i++) {=0A= var lambda =3D arguments[i];=0A= try {=0A= returnValue =3D lambda();=0A= break;=0A= } catch (e) { }=0A= }=0A= =0A= return returnValue;=0A= }=0A= };=0A= =0A= RegExp.prototype.match =3D RegExp.prototype.test;=0A= =0A= RegExp.escape =3D function(str) {=0A= return String(str).replace(/([.*+?^=3D!:${}()|[\]\/\\])/g, '\\$1');=0A= };=0A= =0A= /*-----------------------------------------------------------------------= ---*/=0A= =0A= var PeriodicalExecuter =3D Class.create({=0A= initialize: function(callback, frequency) {=0A= this.callback =3D callback;=0A= this.frequency =3D frequency;=0A= this.currentlyExecuting =3D false;=0A= =0A= this.registerCallback();=0A= },=0A= =0A= registerCallback: function() {=0A= this.timer =3D setInterval(this.onTimerEvent.bind(this), = this.frequency * 1000);=0A= },=0A= =0A= execute: function() {=0A= this.callback(this);=0A= },=0A= =0A= stop: function() {=0A= if (!this.timer) return;=0A= clearInterval(this.timer);=0A= this.timer =3D null;=0A= },=0A= =0A= onTimerEvent: function() {=0A= if (!this.currentlyExecuting) {=0A= try {=0A= this.currentlyExecuting =3D true;=0A= this.execute();=0A= } finally {=0A= this.currentlyExecuting =3D false;=0A= }=0A= }=0A= }=0A= });=0A= Object.extend(String, {=0A= interpret: function(value) {=0A= return value =3D=3D null ? '' : String(value);=0A= },=0A= specialChar: {=0A= '\b': '\\b',=0A= '\t': '\\t',=0A= '\n': '\\n',=0A= '\f': '\\f',=0A= '\r': '\\r',=0A= '\\': '\\\\'=0A= }=0A= });=0A= =0A= Object.extend(String.prototype, {=0A= gsub: function(pattern, replacement) {=0A= var result =3D '', source =3D this, match;=0A= replacement =3D arguments.callee.prepareReplacement(replacement);=0A= =0A= while (source.length > 0) {=0A= if (match =3D source.match(pattern)) {=0A= result +=3D source.slice(0, match.index);=0A= result +=3D String.interpret(replacement(match));=0A= source =3D source.slice(match.index + match[0].length);=0A= } else {=0A= result +=3D source, source =3D '';=0A= }=0A= }=0A= return result;=0A= },=0A= =0A= sub: function(pattern, replacement, count) {=0A= replacement =3D this.gsub.prepareReplacement(replacement);=0A= count =3D Object.isUndefined(count) ? 1 : count;=0A= =0A= return this.gsub(pattern, function(match) {=0A= if (--count < 0) return match[0];=0A= return replacement(match);=0A= });=0A= },=0A= =0A= scan: function(pattern, iterator) {=0A= this.gsub(pattern, iterator);=0A= return String(this);=0A= },=0A= =0A= truncate: function(length, truncation) {=0A= length =3D length || 30;=0A= truncation =3D Object.isUndefined(truncation) ? '...' : truncation;=0A= return this.length > length ?=0A= this.slice(0, length - truncation.length) + truncation : = String(this);=0A= },=0A= =0A= strip: function() {=0A= return this.replace(/^\s+/, '').replace(/\s+$/, '');=0A= },=0A= =0A= stripTags: function() {=0A= return this.replace(/<\/?[^>]+>/gi, '');=0A= },=0A= =0A= stripScripts: function() {=0A= return this.replace(new RegExp(Prototype.ScriptFragment, 'img'), '');=0A= },=0A= =0A= extractScripts: function() {=0A= var matchAll =3D new RegExp(Prototype.ScriptFragment, 'img');=0A= var matchOne =3D new RegExp(Prototype.ScriptFragment, 'im');=0A= return (this.match(matchAll) || []).map(function(scriptTag) {=0A= return (scriptTag.match(matchOne) || ['', ''])[1];=0A= });=0A= },=0A= =0A= evalScripts: function() {=0A= return this.extractScripts().map(function(script) { return = eval(script) });=0A= },=0A= =0A= escapeHTML: function() {=0A= var self =3D arguments.callee;=0A= self.text.data =3D this;=0A= return self.div.innerHTML;=0A= },=0A= =0A= unescapeHTML: function() {=0A= var div =3D new Element('div');=0A= div.innerHTML =3D this.stripTags();=0A= return div.childNodes[0] ? (div.childNodes.length > 1 ?=0A= $A(div.childNodes).inject('', function(memo, node) { return = memo+node.nodeValue }) :=0A= div.childNodes[0].nodeValue) : '';=0A= },=0A= =0A= toQueryParams: function(separator) {=0A= var match =3D this.strip().match(/([^?#]*)(#.*)?$/);=0A= if (!match) return { };=0A= =0A= return match[1].split(separator || '&').inject({ }, function(hash, = pair) {=0A= if ((pair =3D pair.split('=3D'))[0]) {=0A= var key =3D decodeURIComponent(pair.shift());=0A= var value =3D pair.length > 1 ? pair.join('=3D') : pair[0];=0A= if (value !=3D undefined) value =3D decodeURIComponent(value);=0A= =0A= if (key in hash) {=0A= if (!Object.isArray(hash[key])) hash[key] =3D [hash[key]];=0A= hash[key].push(value);=0A= }=0A= else hash[key] =3D value;=0A= }=0A= return hash;=0A= });=0A= },=0A= =0A= toArray: function() {=0A= return this.split('');=0A= },=0A= =0A= succ: function() {=0A= return this.slice(0, this.length - 1) +=0A= String.fromCharCode(this.charCodeAt(this.length - 1) + 1);=0A= },=0A= =0A= times: function(count) {=0A= return count < 1 ? '' : new Array(count + 1).join(this);=0A= },=0A= =0A= camelize: function() {=0A= var parts =3D this.split('-'), len =3D parts.length;=0A= if (len =3D=3D 1) return parts[0];=0A= =0A= var camelized =3D this.charAt(0) =3D=3D '-'=0A= ? parts[0].charAt(0).toUpperCase() + parts[0].substring(1)=0A= : parts[0];=0A= =0A= for (var i =3D 1; i < len; i++)=0A= camelized +=3D parts[i].charAt(0).toUpperCase() + = parts[i].substring(1);=0A= =0A= return camelized;=0A= },=0A= =0A= capitalize: function() {=0A= return this.charAt(0).toUpperCase() + = this.substring(1).toLowerCase();=0A= },=0A= =0A= underscore: function() {=0A= return this.gsub(/::/, = '/').gsub(/([A-Z]+)([A-Z][a-z])/,'#{1}_#{2}').gsub(/([a-z\d])([A-Z])/,'#{= 1}_#{2}').gsub(/-/,'_').toLowerCase();=0A= },=0A= =0A= dasherize: function() {=0A= return this.gsub(/_/,'-');=0A= },=0A= =0A= inspect: function(useDoubleQuotes) {=0A= var escapedString =3D this.gsub(/[\x00-\x1f\\]/, function(match) {=0A= var character =3D String.specialChar[match[0]];=0A= return character ? character : '\\u00' + = match[0].charCodeAt().toPaddedString(2, 16);=0A= });=0A= if (useDoubleQuotes) return '"' + escapedString.replace(/"/g, '\\"') = + '"';=0A= return "'" + escapedString.replace(/'/g, '\\\'') + "'";=0A= },=0A= =0A= toJSON: function() {=0A= return this.inspect(true);=0A= },=0A= =0A= unfilterJSON: function(filter) {=0A= return this.sub(filter || Prototype.JSONFilter, '#{1}');=0A= },=0A= =0A= isJSON: function() {=0A= var str =3D this;=0A= if (str.blank()) return false;=0A= str =3D this.replace(/\\./g, '@').replace(/"[^"\\\n\r]*"/g, '');=0A= return (/^[,:{}\[\]0-9.\-+Eaeflnr-u \n\r\t]*$/).test(str);=0A= },=0A= =0A= evalJSON: function(sanitize) {=0A= var json =3D this.unfilterJSON();=0A= try {=0A= if (!sanitize || json.isJSON()) return eval('(' + json + ')');=0A= } catch (e) { }=0A= throw new SyntaxError('Badly formed JSON string: ' + this.inspect());=0A= },=0A= =0A= include: function(pattern) {=0A= return this.indexOf(pattern) > -1;=0A= },=0A= =0A= startsWith: function(pattern) {=0A= return this.indexOf(pattern) =3D=3D=3D 0;=0A= },=0A= =0A= endsWith: function(pattern) {=0A= var d =3D this.length - pattern.length;=0A= return d >=3D 0 && this.lastIndexOf(pattern) =3D=3D=3D d;=0A= },=0A= =0A= empty: function() {=0A= return this =3D=3D '';=0A= },=0A= =0A= blank: function() {=0A= return /^\s*$/.test(this);=0A= },=0A= =0A= interpolate: function(object, pattern) {=0A= return new Template(this, pattern).evaluate(object);=0A= }=0A= });=0A= =0A= if (Prototype.Browser.WebKit || Prototype.Browser.IE) = Object.extend(String.prototype, {=0A= escapeHTML: function() {=0A= return = this.replace(/&/g,'&').replace(//g,'>');=0A= },=0A= unescapeHTML: function() {=0A= return = this.stripTags().replace(/&/g,'&').replace(/</g,'<').replace(/>= /g,'>');=0A= }=0A= });=0A= =0A= String.prototype.gsub.prepareReplacement =3D function(replacement) {=0A= if (Object.isFunction(replacement)) return replacement;=0A= var template =3D new Template(replacement);=0A= return function(match) { return template.evaluate(match) };=0A= };=0A= =0A= String.prototype.parseQuery =3D String.prototype.toQueryParams;=0A= =0A= Object.extend(String.prototype.escapeHTML, {=0A= div: document.createElement('div'),=0A= text: document.createTextNode('')=0A= });=0A= =0A= String.prototype.escapeHTML.div.appendChild(String.prototype.escapeHTML.t= ext);=0A= =0A= var Template =3D Class.create({=0A= initialize: function(template, pattern) {=0A= this.template =3D template.toString();=0A= this.pattern =3D pattern || Template.Pattern;=0A= },=0A= =0A= evaluate: function(object) {=0A= if (Object.isFunction(object.toTemplateReplacements))=0A= object =3D object.toTemplateReplacements();=0A= =0A= return this.template.gsub(this.pattern, function(match) {=0A= if (object =3D=3D null) return '';=0A= =0A= var before =3D match[1] || '';=0A= if (before =3D=3D '\\') return match[2];=0A= =0A= var ctx =3D object, expr =3D match[3];=0A= var pattern =3D /^([^.[]+|\[((?:.*?[^\\])?)\])(\.|\[|$)/;=0A= match =3D pattern.exec(expr);=0A= if (match =3D=3D null) return before;=0A= =0A= while (match !=3D null) {=0A= var comp =3D match[1].startsWith('[') ? match[2].gsub('\\\\]', = ']') : match[1];=0A= ctx =3D ctx[comp];=0A= if (null =3D=3D ctx || '' =3D=3D match[3]) break;=0A= expr =3D expr.substring('[' =3D=3D match[3] ? match[1].length : = match[0].length);=0A= match =3D pattern.exec(expr);=0A= }=0A= =0A= return before + String.interpret(ctx);=0A= });=0A= }=0A= });=0A= Template.Pattern =3D /(^|.|\r|\n)(#\{(.*?)\})/;=0A= =0A= var $break =3D { };=0A= =0A= var Enumerable =3D {=0A= each: function(iterator, context) {=0A= var index =3D 0;=0A= try {=0A= this._each(function(value) {=0A= iterator.call(context, value, index++);=0A= });=0A= } catch (e) {=0A= if (e !=3D $break) throw e;=0A= }=0A= return this;=0A= },=0A= =0A= eachSlice: function(number, iterator, context) {=0A= var index =3D -number, slices =3D [], array =3D this.toArray();=0A= if (number < 1) return array;=0A= while ((index +=3D number) < array.length)=0A= slices.push(array.slice(index, index+number));=0A= return slices.collect(iterator, context);=0A= },=0A= =0A= all: function(iterator, context) {=0A= iterator =3D iterator || Prototype.K;=0A= var result =3D true;=0A= this.each(function(value, index) {=0A= result =3D result && !!iterator.call(context, value, index);=0A= if (!result) throw $break;=0A= });=0A= return result;=0A= },=0A= =0A= any: function(iterator, context) {=0A= iterator =3D iterator || Prototype.K;=0A= var result =3D false;=0A= this.each(function(value, index) {=0A= if (result =3D !!iterator.call(context, value, index))=0A= throw $break;=0A= });=0A= return result;=0A= },=0A= =0A= collect: function(iterator, context) {=0A= iterator =3D iterator || Prototype.K;=0A= var results =3D [];=0A= this.each(function(value, index) {=0A= results.push(iterator.call(context, value, index));=0A= });=0A= return results;=0A= },=0A= =0A= detect: function(iterator, context) {=0A= var result;=0A= this.each(function(value, index) {=0A= if (iterator.call(context, value, index)) {=0A= result =3D value;=0A= throw $break;=0A= }=0A= });=0A= return result;=0A= },=0A= =0A= findAll: function(iterator, context) {=0A= var results =3D [];=0A= this.each(function(value, index) {=0A= if (iterator.call(context, value, index))=0A= results.push(value);=0A= });=0A= return results;=0A= },=0A= =0A= grep: function(filter, iterator, context) {=0A= iterator =3D iterator || Prototype.K;=0A= var results =3D [];=0A= =0A= if (Object.isString(filter))=0A= filter =3D new RegExp(filter);=0A= =0A= this.each(function(value, index) {=0A= if (filter.match(value))=0A= results.push(iterator.call(context, value, index));=0A= });=0A= return results;=0A= },=0A= =0A= include: function(object) {=0A= if (Object.isFunction(this.indexOf))=0A= if (this.indexOf(object) !=3D -1) return true;=0A= =0A= var found =3D false;=0A= this.each(function(value) {=0A= if (value =3D=3D object) {=0A= found =3D true;=0A= throw $break;=0A= }=0A= });=0A= return found;=0A= },=0A= =0A= inGroupsOf: function(number, fillWith) {=0A= fillWith =3D Object.isUndefined(fillWith) ? null : fillWith;=0A= return this.eachSlice(number, function(slice) {=0A= while(slice.length < number) slice.push(fillWith);=0A= return slice;=0A= });=0A= },=0A= =0A= inject: function(memo, iterator, context) {=0A= this.each(function(value, index) {=0A= memo =3D iterator.call(context, memo, value, index);=0A= });=0A= return memo;=0A= },=0A= =0A= invoke: function(method) {=0A= var args =3D $A(arguments).slice(1);=0A= return this.map(function(value) {=0A= return value[method].apply(value, args);=0A= });=0A= },=0A= =0A= max: function(iterator, context) {=0A= iterator =3D iterator || Prototype.K;=0A= var result;=0A= this.each(function(value, index) {=0A= value =3D iterator.call(context, value, index);=0A= if (result =3D=3D null || value >=3D result)=0A= result =3D value;=0A= });=0A= return result;=0A= },=0A= =0A= min: function(iterator, context) {=0A= iterator =3D iterator || Prototype.K;=0A= var result;=0A= this.each(function(value, index) {=0A= value =3D iterator.call(context, value, index);=0A= if (result =3D=3D null || value < result)=0A= result =3D value;=0A= });=0A= return result;=0A= },=0A= =0A= partition: function(iterator, context) {=0A= iterator =3D iterator || Prototype.K;=0A= var trues =3D [], falses =3D [];=0A= this.each(function(value, index) {=0A= (iterator.call(context, value, index) ?=0A= trues : falses).push(value);=0A= });=0A= return [trues, falses];=0A= },=0A= =0A= pluck: function(property) {=0A= var results =3D [];=0A= this.each(function(value) {=0A= results.push(value[property]);=0A= });=0A= return results;=0A= },=0A= =0A= reject: function(iterator, context) {=0A= var results =3D [];=0A= this.each(function(value, index) {=0A= if (!iterator.call(context, value, index))=0A= results.push(value);=0A= });=0A= return results;=0A= },=0A= =0A= sortBy: function(iterator, context) {=0A= return this.map(function(value, index) {=0A= return {=0A= value: value,=0A= criteria: iterator.call(context, value, index)=0A= };=0A= }).sort(function(left, right) {=0A= var a =3D left.criteria, b =3D right.criteria;=0A= return a < b ? -1 : a > b ? 1 : 0;=0A= }).pluck('value');=0A= },=0A= =0A= toArray: function() {=0A= return this.map();=0A= },=0A= =0A= zip: function() {=0A= var iterator =3D Prototype.K, args =3D $A(arguments);=0A= if (Object.isFunction(args.last()))=0A= iterator =3D args.pop();=0A= =0A= var collections =3D [this].concat(args).map($A);=0A= return this.map(function(value, index) {=0A= return iterator(collections.pluck(index));=0A= });=0A= },=0A= =0A= size: function() {=0A= return this.toArray().length;=0A= },=0A= =0A= inspect: function() {=0A= return '#';=0A= }=0A= };=0A= =0A= Object.extend(Enumerable, {=0A= map: Enumerable.collect,=0A= find: Enumerable.detect,=0A= select: Enumerable.findAll,=0A= filter: Enumerable.findAll,=0A= member: Enumerable.include,=0A= entries: Enumerable.toArray,=0A= every: Enumerable.all,=0A= some: Enumerable.any=0A= });=0A= function $A(iterable) {=0A= if (!iterable) return [];=0A= if (iterable.toArray) return iterable.toArray();=0A= var length =3D iterable.length || 0, results =3D new Array(length);=0A= while (length--) results[length] =3D iterable[length];=0A= return results;=0A= }=0A= =0A= if (Prototype.Browser.WebKit) {=0A= $A =3D function(iterable) {=0A= if (!iterable) return [];=0A= // In Safari, only use the `toArray` method if it's not a NodeList.=0A= // A NodeList is a function, has an function `item` property, and a = numeric=0A= // `length` property. Adapted from Google Doctype.=0A= if (!(typeof iterable =3D=3D=3D 'function' && typeof iterable.length = =3D=3D=3D=0A= 'number' && typeof iterable.item =3D=3D=3D 'function') && = iterable.toArray)=0A= return iterable.toArray();=0A= var length =3D iterable.length || 0, results =3D new Array(length);=0A= while (length--) results[length] =3D iterable[length];=0A= return results;=0A= };=0A= }=0A= =0A= Array.from =3D $A;=0A= =0A= Object.extend(Array.prototype, Enumerable);=0A= =0A= if (!Array.prototype._reverse) Array.prototype._reverse =3D = Array.prototype.reverse;=0A= =0A= Object.extend(Array.prototype, {=0A= _each: function(iterator) {=0A= for (var i =3D 0, length =3D this.length; i < length; i++)=0A= iterator(this[i]);=0A= },=0A= =0A= clear: function() {=0A= this.length =3D 0;=0A= return this;=0A= },=0A= =0A= first: function() {=0A= return this[0];=0A= },=0A= =0A= last: function() {=0A= return this[this.length - 1];=0A= },=0A= =0A= compact: function() {=0A= return this.select(function(value) {=0A= return value !=3D null;=0A= });=0A= },=0A= =0A= flatten: function() {=0A= return this.inject([], function(array, value) {=0A= return array.concat(Object.isArray(value) ?=0A= value.flatten() : [value]);=0A= });=0A= },=0A= =0A= without: function() {=0A= var values =3D $A(arguments);=0A= return this.select(function(value) {=0A= return !values.include(value);=0A= });=0A= },=0A= =0A= reverse: function(inline) {=0A= return (inline !=3D=3D false ? this : this.toArray())._reverse();=0A= },=0A= =0A= reduce: function() {=0A= return this.length > 1 ? this : this[0];=0A= },=0A= =0A= uniq: function(sorted) {=0A= return this.inject([], function(array, value, index) {=0A= if (0 =3D=3D index || (sorted ? array.last() !=3D value : = !array.include(value)))=0A= array.push(value);=0A= return array;=0A= });=0A= },=0A= =0A= intersect: function(array) {=0A= return this.uniq().findAll(function(item) {=0A= return array.detect(function(value) { return item =3D=3D=3D value = });=0A= });=0A= },=0A= =0A= clone: function() {=0A= return [].concat(this);=0A= },=0A= =0A= size: function() {=0A= return this.length;=0A= },=0A= =0A= inspect: function() {=0A= return '[' + this.map(Object.inspect).join(', ') + ']';=0A= },=0A= =0A= toJSON: function() {=0A= var results =3D [];=0A= this.each(function(object) {=0A= var value =3D Object.toJSON(object);=0A= if (!Object.isUndefined(value)) results.push(value);=0A= });=0A= return '[' + results.join(', ') + ']';=0A= }=0A= });=0A= =0A= // use native browser JS 1.6 implementation if available=0A= if (Object.isFunction(Array.prototype.forEach))=0A= Array.prototype._each =3D Array.prototype.forEach;=0A= =0A= if (!Array.prototype.indexOf) Array.prototype.indexOf =3D function(item, = i) {=0A= i || (i =3D 0);=0A= var length =3D this.length;=0A= if (i < 0) i =3D length + i;=0A= for (; i < length; i++)=0A= if (this[i] =3D=3D=3D item) return i;=0A= return -1;=0A= };=0A= =0A= if (!Array.prototype.lastIndexOf) Array.prototype.lastIndexOf =3D = function(item, i) {=0A= i =3D isNaN(i) ? this.length : (i < 0 ? this.length + i : i) + 1;=0A= var n =3D this.slice(0, i).reverse().indexOf(item);=0A= return (n < 0) ? n : i - n - 1;=0A= };=0A= =0A= Array.prototype.toArray =3D Array.prototype.clone;=0A= =0A= function $w(string) {=0A= if (!Object.isString(string)) return [];=0A= string =3D string.strip();=0A= return string ? string.split(/\s+/) : [];=0A= }=0A= =0A= if (Prototype.Browser.Opera){=0A= Array.prototype.concat =3D function() {=0A= var array =3D [];=0A= for (var i =3D 0, length =3D this.length; i < length; i++) = array.push(this[i]);=0A= for (var i =3D 0, length =3D arguments.length; i < length; i++) {=0A= if (Object.isArray(arguments[i])) {=0A= for (var j =3D 0, arrayLength =3D arguments[i].length; j < = arrayLength; j++)=0A= array.push(arguments[i][j]);=0A= } else {=0A= array.push(arguments[i]);=0A= }=0A= }=0A= return array;=0A= };=0A= }=0A= Object.extend(Number.prototype, {=0A= toColorPart: function() {=0A= return this.toPaddedString(2, 16);=0A= },=0A= =0A= succ: function() {=0A= return this + 1;=0A= },=0A= =0A= times: function(iterator, context) {=0A= $R(0, this, true).each(iterator, context);=0A= return this;=0A= },=0A= =0A= toPaddedString: function(length, radix) {=0A= var string =3D this.toString(radix || 10);=0A= return '0'.times(length - string.length) + string;=0A= },=0A= =0A= toJSON: function() {=0A= return isFinite(this) ? this.toString() : 'null';=0A= }=0A= });=0A= =0A= $w('abs round ceil floor').each(function(method){=0A= Number.prototype[method] =3D Math[method].methodize();=0A= });=0A= function $H(object) {=0A= return new Hash(object);=0A= };=0A= =0A= var Hash =3D Class.create(Enumerable, (function() {=0A= =0A= function toQueryPair(key, value) {=0A= if (Object.isUndefined(value)) return key;=0A= return key + '=3D' + encodeURIComponent(String.interpret(value));=0A= }=0A= =0A= return {=0A= initialize: function(object) {=0A= this._object =3D Object.isHash(object) ? object.toObject() : = Object.clone(object);=0A= },=0A= =0A= _each: function(iterator) {=0A= for (var key in this._object) {=0A= var value =3D this._object[key], pair =3D [key, value];=0A= pair.key =3D key;=0A= pair.value =3D value;=0A= iterator(pair);=0A= }=0A= },=0A= =0A= set: function(key, value) {=0A= return this._object[key] =3D value;=0A= },=0A= =0A= get: function(key) {=0A= // simulating poorly supported hasOwnProperty=0A= if (this._object[key] !=3D=3D Object.prototype[key])=0A= return this._object[key];=0A= },=0A= =0A= unset: function(key) {=0A= var value =3D this._object[key];=0A= delete this._object[key];=0A= return value;=0A= },=0A= =0A= toObject: function() {=0A= return Object.clone(this._object);=0A= },=0A= =0A= keys: function() {=0A= return this.pluck('key');=0A= },=0A= =0A= values: function() {=0A= return this.pluck('value');=0A= },=0A= =0A= index: function(value) {=0A= var match =3D this.detect(function(pair) {=0A= return pair.value =3D=3D=3D value;=0A= });=0A= return match && match.key;=0A= },=0A= =0A= merge: function(object) {=0A= return this.clone().update(object);=0A= },=0A= =0A= update: function(object) {=0A= return new Hash(object).inject(this, function(result, pair) {=0A= result.set(pair.key, pair.value);=0A= return result;=0A= });=0A= },=0A= =0A= toQueryString: function() {=0A= return this.inject([], function(results, pair) {=0A= var key =3D encodeURIComponent(pair.key), values =3D pair.value;=0A= =0A= if (values && typeof values =3D=3D 'object') {=0A= if (Object.isArray(values))=0A= return results.concat(values.map(toQueryPair.curry(key)));=0A= } else results.push(toQueryPair(key, values));=0A= return results;=0A= }).join('&');=0A= },=0A= =0A= inspect: function() {=0A= return '#';=0A= },=0A= =0A= toJSON: function() {=0A= return Object.toJSON(this.toObject());=0A= },=0A= =0A= clone: function() {=0A= return new Hash(this);=0A= }=0A= }=0A= })());=0A= =0A= Hash.prototype.toTemplateReplacements =3D Hash.prototype.toObject;=0A= Hash.from =3D $H;=0A= var ObjectRange =3D Class.create(Enumerable, {=0A= initialize: function(start, end, exclusive) {=0A= this.start =3D start;=0A= this.end =3D end;=0A= this.exclusive =3D exclusive;=0A= },=0A= =0A= _each: function(iterator) {=0A= var value =3D this.start;=0A= while (this.include(value)) {=0A= iterator(value);=0A= value =3D value.succ();=0A= }=0A= },=0A= =0A= include: function(value) {=0A= if (value < this.start)=0A= return false;=0A= if (this.exclusive)=0A= return value < this.end;=0A= return value <=3D this.end;=0A= }=0A= });=0A= =0A= var $R =3D function(start, end, exclusive) {=0A= return new ObjectRange(start, end, exclusive);=0A= };=0A= =0A= var Ajax =3D {=0A= getTransport: function() {=0A= return Try.these(=0A= function() {return new XMLHttpRequest()},=0A= function() {return new ActiveXObject('Msxml2.XMLHTTP')},=0A= function() {return new ActiveXObject('Microsoft.XMLHTTP')}=0A= ) || false;=0A= },=0A= =0A= activeRequestCount: 0=0A= };=0A= =0A= Ajax.Responders =3D {=0A= responders: [],=0A= =0A= _each: function(iterator) {=0A= this.responders._each(iterator);=0A= },=0A= =0A= register: function(responder) {=0A= if (!this.include(responder))=0A= this.responders.push(responder);=0A= },=0A= =0A= unregister: function(responder) {=0A= this.responders =3D this.responders.without(responder);=0A= },=0A= =0A= dispatch: function(callback, request, transport, json) {=0A= this.each(function(responder) {=0A= if (Object.isFunction(responder[callback])) {=0A= try {=0A= responder[callback].apply(responder, [request, transport, = json]);=0A= } catch (e) { }=0A= }=0A= });=0A= }=0A= };=0A= =0A= Object.extend(Ajax.Responders, Enumerable);=0A= =0A= Ajax.Responders.register({=0A= onCreate: function() { Ajax.activeRequestCount++ },=0A= onComplete: function() { Ajax.activeRequestCount-- }=0A= });=0A= =0A= Ajax.Base =3D Class.create({=0A= initialize: function(options) {=0A= this.options =3D {=0A= method: 'post',=0A= asynchronous: true,=0A= contentType: 'application/x-www-form-urlencoded',=0A= encoding: 'UTF-8',=0A= parameters: '',=0A= evalJSON: true,=0A= evalJS: true=0A= };=0A= Object.extend(this.options, options || { });=0A= =0A= this.options.method =3D this.options.method.toLowerCase();=0A= =0A= if (Object.isString(this.options.parameters))=0A= this.options.parameters =3D = this.options.parameters.toQueryParams();=0A= else if (Object.isHash(this.options.parameters))=0A= this.options.parameters =3D this.options.parameters.toObject();=0A= }=0A= });=0A= =0A= Ajax.Request =3D Class.create(Ajax.Base, {=0A= _complete: false,=0A= =0A= initialize: function($super, url, options) {=0A= $super(options);=0A= this.transport =3D Ajax.getTransport();=0A= this.request(url);=0A= },=0A= =0A= request: function(url) {=0A= this.url =3D url;=0A= this.method =3D this.options.method;=0A= var params =3D Object.clone(this.options.parameters);=0A= =0A= if (!['get', 'post'].include(this.method)) {=0A= // simulate other verbs over post=0A= params['_method'] =3D this.method;=0A= this.method =3D 'post';=0A= }=0A= =0A= this.parameters =3D params;=0A= =0A= if (params =3D Object.toQueryString(params)) {=0A= // when GET, append parameters to URL=0A= if (this.method =3D=3D 'get')=0A= this.url +=3D (this.url.include('?') ? '&' : '?') + params;=0A= else if (/Konqueror|Safari|KHTML/.test(navigator.userAgent))=0A= params +=3D '&_=3D';=0A= }=0A= =0A= try {=0A= var response =3D new Ajax.Response(this);=0A= if (this.options.onCreate) this.options.onCreate(response);=0A= Ajax.Responders.dispatch('onCreate', this, response);=0A= =0A= this.transport.open(this.method.toUpperCase(), this.url,=0A= this.options.asynchronous);=0A= =0A= if (this.options.asynchronous) = this.respondToReadyState.bind(this).defer(1);=0A= =0A= this.transport.onreadystatechange =3D = this.onStateChange.bind(this);=0A= this.setRequestHeaders();=0A= =0A= this.body =3D this.method =3D=3D 'post' ? (this.options.postBody = || params) : null;=0A= this.transport.send(this.body);=0A= =0A= /* Force Firefox to handle ready state 4 for synchronous requests = */=0A= if (!this.options.asynchronous && this.transport.overrideMimeType)=0A= this.onStateChange();=0A= =0A= }=0A= catch (e) {=0A= this.dispatchException(e);=0A= }=0A= },=0A= =0A= onStateChange: function() {=0A= var readyState =3D this.transport.readyState;=0A= if (readyState > 1 && !((readyState =3D=3D 4) && this._complete))=0A= this.respondToReadyState(this.transport.readyState);=0A= },=0A= =0A= setRequestHeaders: function() {=0A= var headers =3D {=0A= 'X-Requested-With': 'XMLHttpRequest',=0A= 'X-Prototype-Version': Prototype.Version,=0A= 'Accept': 'text/javascript, text/html, application/xml, text/xml, = */*'=0A= };=0A= =0A= if (this.method =3D=3D 'post') {=0A= headers['Content-type'] =3D this.options.contentType +=0A= (this.options.encoding ? '; charset=3D' + this.options.encoding = : '');=0A= =0A= /* Force "Connection: close" for older Mozilla browsers to work=0A= * around a bug where XMLHttpRequest sends an incorrect=0A= * Content-length header. See Mozilla Bugzilla #246651.=0A= */=0A= if (this.transport.overrideMimeType &&=0A= (navigator.userAgent.match(/Gecko\/(\d{4})/) || [0,2005])[1] < = 2005)=0A= headers['Connection'] =3D 'close';=0A= }=0A= =0A= // user-defined headers=0A= if (typeof this.options.requestHeaders =3D=3D 'object') {=0A= var extras =3D this.options.requestHeaders;=0A= =0A= if (Object.isFunction(extras.push))=0A= for (var i =3D 0, length =3D extras.length; i < length; i +=3D 2)=0A= headers[extras[i]] =3D extras[i+1];=0A= else=0A= $H(extras).each(function(pair) { headers[pair.key] =3D = pair.value });=0A= }=0A= =0A= for (var name in headers)=0A= this.transport.setRequestHeader(name, headers[name]);=0A= },=0A= =0A= success: function() {=0A= var status =3D this.getStatus();=0A= return !status || (status >=3D 200 && status < 300);=0A= },=0A= =0A= getStatus: function() {=0A= try {=0A= return this.transport.status || 0;=0A= } catch (e) { return 0 }=0A= },=0A= =0A= respondToReadyState: function(readyState) {=0A= var state =3D Ajax.Request.Events[readyState], response =3D new = Ajax.Response(this);=0A= =0A= if (state =3D=3D 'Complete') {=0A= try {=0A= this._complete =3D true;=0A= (this.options['on' + response.status]=0A= || this.options['on' + (this.success() ? 'Success' : 'Failure')]=0A= || Prototype.emptyFunction)(response, response.headerJSON);=0A= } catch (e) {=0A= this.dispatchException(e);=0A= }=0A= =0A= var contentType =3D response.getHeader('Content-type');=0A= if (this.options.evalJS =3D=3D 'force'=0A= || (this.options.evalJS && this.isSameOrigin() && contentType=0A= && = contentType.match(/^\s*(text|application)\/(x-)?(java|ecma)script(;.*)?\s= *$/i)))=0A= this.evalResponse();=0A= }=0A= =0A= try {=0A= (this.options['on' + state] || Prototype.emptyFunction)(response, = response.headerJSON);=0A= Ajax.Responders.dispatch('on' + state, this, response, = response.headerJSON);=0A= } catch (e) {=0A= this.dispatchException(e);=0A= }=0A= =0A= if (state =3D=3D 'Complete') {=0A= // avoid memory leak in MSIE: clean up=0A= this.transport.onreadystatechange =3D Prototype.emptyFunction;=0A= }=0A= },=0A= =0A= isSameOrigin: function() {=0A= var m =3D this.url.match(/^\s*https?:\/\/[^\/]*/);=0A= return !m || (m[0] =3D=3D = '#{protocol}//#{domain}#{port}'.interpolate({=0A= protocol: location.protocol,=0A= domain: document.domain,=0A= port: location.port ? ':' + location.port : ''=0A= }));=0A= },=0A= =0A= getHeader: function(name) {=0A= try {=0A= return this.transport.getResponseHeader(name) || null;=0A= } catch (e) { return null }=0A= },=0A= =0A= evalResponse: function() {=0A= try {=0A= return eval((this.transport.responseText || '').unfilterJSON());=0A= } catch (e) {=0A= this.dispatchException(e);=0A= }=0A= },=0A= =0A= dispatchException: function(exception) {=0A= (this.options.onException || Prototype.emptyFunction)(this, = exception);=0A= Ajax.Responders.dispatch('onException', this, exception);=0A= }=0A= });=0A= =0A= Ajax.Request.Events =3D=0A= ['Uninitialized', 'Loading', 'Loaded', 'Interactive', 'Complete'];=0A= =0A= Ajax.Response =3D Class.create({=0A= initialize: function(request){=0A= this.request =3D request;=0A= var transport =3D this.transport =3D request.transport,=0A= readyState =3D this.readyState =3D transport.readyState;=0A= =0A= if((readyState > 2 && !Prototype.Browser.IE) || readyState =3D=3D 4) = {=0A= this.status =3D this.getStatus();=0A= this.statusText =3D this.getStatusText();=0A= this.responseText =3D String.interpret(transport.responseText);=0A= this.headerJSON =3D this._getHeaderJSON();=0A= }=0A= =0A= if(readyState =3D=3D 4) {=0A= var xml =3D transport.responseXML;=0A= this.responseXML =3D Object.isUndefined(xml) ? null : xml;=0A= this.responseJSON =3D this._getResponseJSON();=0A= }=0A= },=0A= =0A= status: 0,=0A= statusText: '',=0A= =0A= getStatus: Ajax.Request.prototype.getStatus,=0A= =0A= getStatusText: function() {=0A= try {=0A= return this.transport.statusText || '';=0A= } catch (e) { return '' }=0A= },=0A= =0A= getHeader: Ajax.Request.prototype.getHeader,=0A= =0A= getAllHeaders: function() {=0A= try {=0A= return this.getAllResponseHeaders();=0A= } catch (e) { return null }=0A= },=0A= =0A= getResponseHeader: function(name) {=0A= return this.transport.getResponseHeader(name);=0A= },=0A= =0A= getAllResponseHeaders: function() {=0A= return this.transport.getAllResponseHeaders();=0A= },=0A= =0A= _getHeaderJSON: function() {=0A= var json =3D this.getHeader('X-JSON');=0A= if (!json) return null;=0A= json =3D decodeURIComponent(escape(json));=0A= try {=0A= return json.evalJSON(this.request.options.sanitizeJSON ||=0A= !this.request.isSameOrigin());=0A= } catch (e) {=0A= this.request.dispatchException(e);=0A= }=0A= },=0A= =0A= _getResponseJSON: function() {=0A= var options =3D this.request.options;=0A= if (!options.evalJSON || (options.evalJSON !=3D 'force' &&=0A= !(this.getHeader('Content-type') || = '').include('application/json')) ||=0A= this.responseText.blank())=0A= return null;=0A= try {=0A= return this.responseText.evalJSON(options.sanitizeJSON ||=0A= !this.request.isSameOrigin());=0A= } catch (e) {=0A= this.request.dispatchException(e);=0A= }=0A= }=0A= });=0A= =0A= Ajax.Updater =3D Class.create(Ajax.Request, {=0A= initialize: function($super, container, url, options) {=0A= this.container =3D {=0A= success: (container.success || container),=0A= failure: (container.failure || (container.success ? null : = container))=0A= };=0A= =0A= options =3D Object.clone(options);=0A= var onComplete =3D options.onComplete;=0A= options.onComplete =3D (function(response, json) {=0A= this.updateContent(response.responseText);=0A= if (Object.isFunction(onComplete)) onComplete(response, json);=0A= }).bind(this);=0A= =0A= $super(url, options);=0A= },=0A= =0A= updateContent: function(responseText) {=0A= var receiver =3D this.container[this.success() ? 'success' : = 'failure'],=0A= options =3D this.options;=0A= =0A= if (!options.evalScripts) responseText =3D = responseText.stripScripts();=0A= =0A= if (receiver =3D $(receiver)) {=0A= if (options.insertion) {=0A= if (Object.isString(options.insertion)) {=0A= var insertion =3D { }; insertion[options.insertion] =3D = responseText;=0A= receiver.insert(insertion);=0A= }=0A= else options.insertion(receiver, responseText);=0A= }=0A= else receiver.update(responseText);=0A= }=0A= }=0A= });=0A= =0A= Ajax.PeriodicalUpdater =3D Class.create(Ajax.Base, {=0A= initialize: function($super, container, url, options) {=0A= $super(options);=0A= this.onComplete =3D this.options.onComplete;=0A= =0A= this.frequency =3D (this.options.frequency || 2);=0A= this.decay =3D (this.options.decay || 1);=0A= =0A= this.updater =3D { };=0A= this.container =3D container;=0A= this.url =3D url;=0A= =0A= this.start();=0A= },=0A= =0A= start: function() {=0A= this.options.onComplete =3D this.updateComplete.bind(this);=0A= this.onTimerEvent();=0A= },=0A= =0A= stop: function() {=0A= this.updater.options.onComplete =3D undefined;=0A= clearTimeout(this.timer);=0A= (this.onComplete || Prototype.emptyFunction).apply(this, arguments);=0A= },=0A= =0A= updateComplete: function(response) {=0A= if (this.options.decay) {=0A= this.decay =3D (response.responseText =3D=3D this.lastText ?=0A= this.decay * this.options.decay : 1);=0A= =0A= this.lastText =3D response.responseText;=0A= }=0A= this.timer =3D this.onTimerEvent.bind(this).delay(this.decay * = this.frequency);=0A= },=0A= =0A= onTimerEvent: function() {=0A= this.updater =3D new Ajax.Updater(this.container, this.url, = this.options);=0A= }=0A= });=0A= function $(element) {=0A= if (arguments.length > 1) {=0A= for (var i =3D 0, elements =3D [], length =3D arguments.length; i < = length; i++)=0A= elements.push($(arguments[i]));=0A= return elements;=0A= }=0A= if (Object.isString(element))=0A= element =3D document.getElementById(element);=0A= return Element.extend(element);=0A= }=0A= =0A= if (Prototype.BrowserFeatures.XPath) {=0A= document._getElementsByXPath =3D function(expression, parentElement) {=0A= var results =3D [];=0A= var query =3D document.evaluate(expression, $(parentElement) || = document,=0A= null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);=0A= for (var i =3D 0, length =3D query.snapshotLength; i < length; i++)=0A= results.push(Element.extend(query.snapshotItem(i)));=0A= return results;=0A= };=0A= }=0A= =0A= /*-----------------------------------------------------------------------= ---*/=0A= =0A= if (!window.Node) var Node =3D { };=0A= =0A= if (!Node.ELEMENT_NODE) {=0A= // DOM level 2 ECMAScript Language Binding=0A= Object.extend(Node, {=0A= ELEMENT_NODE: 1,=0A= ATTRIBUTE_NODE: 2,=0A= TEXT_NODE: 3,=0A= CDATA_SECTION_NODE: 4,=0A= ENTITY_REFERENCE_NODE: 5,=0A= ENTITY_NODE: 6,=0A= PROCESSING_INSTRUCTION_NODE: 7,=0A= COMMENT_NODE: 8,=0A= DOCUMENT_NODE: 9,=0A= DOCUMENT_TYPE_NODE: 10,=0A= DOCUMENT_FRAGMENT_NODE: 11,=0A= NOTATION_NODE: 12=0A= });=0A= }=0A= =0A= (function() {=0A= var element =3D this.Element;=0A= this.Element =3D function(tagName, attributes) {=0A= attributes =3D attributes || { };=0A= tagName =3D tagName.toLowerCase();=0A= var cache =3D Element.cache;=0A= if (Prototype.Browser.IE && attributes.name) {=0A= tagName =3D '<' + tagName + ' name=3D"' + attributes.name + '">';=0A= delete attributes.name;=0A= return Element.writeAttribute(document.createElement(tagName), = attributes);=0A= }=0A= if (!cache[tagName]) cache[tagName] =3D = Element.extend(document.createElement(tagName));=0A= return Element.writeAttribute(cache[tagName].cloneNode(false), = attributes);=0A= };=0A= Object.extend(this.Element, element || { });=0A= if (element) this.Element.prototype =3D element.prototype;=0A= }).call(window);=0A= =0A= Element.cache =3D { };=0A= =0A= Element.Methods =3D {=0A= visible: function(element) {=0A= return $(element).style.display !=3D 'none';=0A= },=0A= =0A= toggle: function(element) {=0A= element =3D $(element);=0A= Element[Element.visible(element) ? 'hide' : 'show'](element);=0A= return element;=0A= },=0A= =0A= hide: function(element) {=0A= element =3D $(element);=0A= element.style.display =3D 'none';=0A= return element;=0A= },=0A= =0A= show: function(element) {=0A= element =3D $(element);=0A= element.style.display =3D '';=0A= return element;=0A= },=0A= =0A= remove: function(element) {=0A= element =3D $(element);=0A= element.parentNode.removeChild(element);=0A= return element;=0A= },=0A= =0A= update: function(element, content) {=0A= element =3D $(element);=0A= if (content && content.toElement) content =3D content.toElement();=0A= if (Object.isElement(content)) return = element.update().insert(content);=0A= content =3D Object.toHTML(content);=0A= element.innerHTML =3D content.stripScripts();=0A= content.evalScripts.bind(content).defer();=0A= return element;=0A= },=0A= =0A= replace: function(element, content) {=0A= element =3D $(element);=0A= if (content && content.toElement) content =3D content.toElement();=0A= else if (!Object.isElement(content)) {=0A= content =3D Object.toHTML(content);=0A= var range =3D element.ownerDocument.createRange();=0A= range.selectNode(element);=0A= content.evalScripts.bind(content).defer();=0A= content =3D range.createContextualFragment(content.stripScripts());=0A= }=0A= element.parentNode.replaceChild(content, element);=0A= return element;=0A= },=0A= =0A= insert: function(element, insertions) {=0A= element =3D $(element);=0A= =0A= if (Object.isString(insertions) || Object.isNumber(insertions) ||=0A= Object.isElement(insertions) || (insertions && = (insertions.toElement || insertions.toHTML)))=0A= insertions =3D {bottom:insertions};=0A= =0A= var content, insert, tagName, childNodes;=0A= =0A= for (var position in insertions) {=0A= content =3D insertions[position];=0A= position =3D position.toLowerCase();=0A= insert =3D Element._insertionTranslations[position];=0A= =0A= if (content && content.toElement) content =3D content.toElement();=0A= if (Object.isElement(content)) {=0A= insert(element, content);=0A= continue;=0A= }=0A= =0A= content =3D Object.toHTML(content);=0A= =0A= tagName =3D ((position =3D=3D 'before' || position =3D=3D 'after')=0A= ? element.parentNode : element).tagName.toUpperCase();=0A= =0A= childNodes =3D Element._getContentFromAnonymousElement(tagName, = content.stripScripts());=0A= =0A= if (position =3D=3D 'top' || position =3D=3D 'after') = childNodes.reverse();=0A= childNodes.each(insert.curry(element));=0A= =0A= content.evalScripts.bind(content).defer();=0A= }=0A= =0A= return element;=0A= },=0A= =0A= wrap: function(element, wrapper, attributes) {=0A= element =3D $(element);=0A= if (Object.isElement(wrapper))=0A= $(wrapper).writeAttribute(attributes || { });=0A= else if (Object.isString(wrapper)) wrapper =3D new Element(wrapper, = attributes);=0A= else wrapper =3D new Element('div', wrapper);=0A= if (element.parentNode)=0A= element.parentNode.replaceChild(wrapper, element);=0A= wrapper.appendChild(element);=0A= return wrapper;=0A= },=0A= =0A= inspect: function(element) {=0A= element =3D $(element);=0A= var result =3D '<' + element.tagName.toLowerCase();=0A= $H({'id': 'id', 'className': 'class'}).each(function(pair) {=0A= var property =3D pair.first(), attribute =3D pair.last();=0A= var value =3D (element[property] || '').toString();=0A= if (value) result +=3D ' ' + attribute + '=3D' + = value.inspect(true);=0A= });=0A= return result + '>';=0A= },=0A= =0A= recursivelyCollect: function(element, property) {=0A= element =3D $(element);=0A= var elements =3D [];=0A= while (element =3D element[property])=0A= if (element.nodeType =3D=3D 1)=0A= elements.push(Element.extend(element));=0A= return elements;=0A= },=0A= =0A= ancestors: function(element) {=0A= return $(element).recursivelyCollect('parentNode');=0A= },=0A= =0A= descendants: function(element) {=0A= return $(element).select("*");=0A= },=0A= =0A= firstDescendant: function(element) {=0A= element =3D $(element).firstChild;=0A= while (element && element.nodeType !=3D 1) element =3D = element.nextSibling;=0A= return $(element);=0A= },=0A= =0A= immediateDescendants: function(element) {=0A= if (!(element =3D $(element).firstChild)) return [];=0A= while (element && element.nodeType !=3D 1) element =3D = element.nextSibling;=0A= if (element) return [element].concat($(element).nextSiblings());=0A= return [];=0A= },=0A= =0A= previousSiblings: function(element) {=0A= return $(element).recursivelyCollect('previousSibling');=0A= },=0A= =0A= nextSiblings: function(element) {=0A= return $(element).recursivelyCollect('nextSibling');=0A= },=0A= =0A= siblings: function(element) {=0A= element =3D $(element);=0A= return = element.previousSiblings().reverse().concat(element.nextSiblings());=0A= },=0A= =0A= match: function(element, selector) {=0A= if (Object.isString(selector))=0A= selector =3D new Selector(selector);=0A= return selector.match($(element));=0A= },=0A= =0A= up: function(element, expression, index) {=0A= element =3D $(element);=0A= if (arguments.length =3D=3D 1) return $(element.parentNode);=0A= var ancestors =3D element.ancestors();=0A= return Object.isNumber(expression) ? ancestors[expression] :=0A= Selector.findElement(ancestors, expression, index);=0A= },=0A= =0A= down: function(element, expression, index) {=0A= element =3D $(element);=0A= if (arguments.length =3D=3D 1) return element.firstDescendant();=0A= return Object.isNumber(expression) ? = element.descendants()[expression] :=0A= Element.select(element, expression)[index || 0];=0A= },=0A= =0A= previous: function(element, expression, index) {=0A= element =3D $(element);=0A= if (arguments.length =3D=3D 1) return = $(Selector.handlers.previousElementSibling(element));=0A= var previousSiblings =3D element.previousSiblings();=0A= return Object.isNumber(expression) ? previousSiblings[expression] :=0A= Selector.findElement(previousSiblings, expression, index);=0A= },=0A= =0A= next: function(element, expression, index) {=0A= element =3D $(element);=0A= if (arguments.length =3D=3D 1) return = $(Selector.handlers.nextElementSibling(element));=0A= var nextSiblings =3D element.nextSiblings();=0A= return Object.isNumber(expression) ? nextSiblings[expression] :=0A= Selector.findElement(nextSiblings, expression, index);=0A= },=0A= =0A= select: function() {=0A= var args =3D $A(arguments), element =3D $(args.shift());=0A= return Selector.findChildElements(element, args);=0A= },=0A= =0A= adjacent: function() {=0A= var args =3D $A(arguments), element =3D $(args.shift());=0A= return Selector.findChildElements(element.parentNode, = args).without(element);=0A= },=0A= =0A= identify: function(element) {=0A= element =3D $(element);=0A= var id =3D element.readAttribute('id'), self =3D arguments.callee;=0A= if (id) return id;=0A= do { id =3D 'anonymous_element_' + self.counter++ } while ($(id));=0A= element.writeAttribute('id', id);=0A= return id;=0A= },=0A= =0A= readAttribute: function(element, name) {=0A= element =3D $(element);=0A= if (Prototype.Browser.IE) {=0A= var t =3D Element._attributeTranslations.read;=0A= if (t.values[name]) return t.values[name](element, name);=0A= if (t.names[name]) name =3D t.names[name];=0A= if (name.include(':')) {=0A= return (!element.attributes || !element.attributes[name]) ? null = :=0A= element.attributes[name].value;=0A= }=0A= }=0A= return element.getAttribute(name);=0A= },=0A= =0A= writeAttribute: function(element, name, value) {=0A= element =3D $(element);=0A= var attributes =3D { }, t =3D Element._attributeTranslations.write;=0A= =0A= if (typeof name =3D=3D 'object') attributes =3D name;=0A= else attributes[name] =3D Object.isUndefined(value) ? true : value;=0A= =0A= for (var attr in attributes) {=0A= name =3D t.names[attr] || attr;=0A= value =3D attributes[attr];=0A= if (t.values[attr]) name =3D t.values[attr](element, value);=0A= if (value =3D=3D=3D false || value =3D=3D=3D null)=0A= element.removeAttribute(name);=0A= else if (value =3D=3D=3D true)=0A= element.setAttribute(name, name);=0A= else element.setAttribute(name, value);=0A= }=0A= return element;=0A= },=0A= =0A= getHeight: function(element) {=0A= return $(element).getDimensions().height;=0A= },=0A= =0A= getWidth: function(element) {=0A= return $(element).getDimensions().width;=0A= },=0A= =0A= classNames: function(element) {=0A= return new Element.ClassNames(element);=0A= },=0A= =0A= hasClassName: function(element, className) {=0A= if (!(element =3D $(element))) return;=0A= var elementClassName =3D element.className;=0A= return (elementClassName.length > 0 && (elementClassName =3D=3D = className ||=0A= new RegExp("(^|\\s)" + className + = "(\\s|$)").test(elementClassName)));=0A= },=0A= =0A= addClassName: function(element, className) {=0A= if (!(element =3D $(element))) return;=0A= if (!element.hasClassName(className))=0A= element.className +=3D (element.className ? ' ' : '') + className;=0A= return element;=0A= },=0A= =0A= removeClassName: function(element, className) {=0A= if (!(element =3D $(element))) return;=0A= element.className =3D element.className.replace(=0A= new RegExp("(^|\\s+)" + className + "(\\s+|$)"), ' ').strip();=0A= return element;=0A= },=0A= =0A= toggleClassName: function(element, className) {=0A= if (!(element =3D $(element))) return;=0A= return element[element.hasClassName(className) ?=0A= 'removeClassName' : 'addClassName'](className);=0A= },=0A= =0A= // removes whitespace-only text node children=0A= cleanWhitespace: function(element) {=0A= element =3D $(element);=0A= var node =3D element.firstChild;=0A= while (node) {=0A= var nextNode =3D node.nextSibling;=0A= if (node.nodeType =3D=3D 3 && !/\S/.test(node.nodeValue))=0A= element.removeChild(node);=0A= node =3D nextNode;=0A= }=0A= return element;=0A= },=0A= =0A= empty: function(element) {=0A= return $(element).innerHTML.blank();=0A= },=0A= =0A= descendantOf: function(element, ancestor) {=0A= element =3D $(element), ancestor =3D $(ancestor);=0A= =0A= if (element.compareDocumentPosition)=0A= return (element.compareDocumentPosition(ancestor) & 8) =3D=3D=3D 8;=0A= =0A= if (ancestor.contains)=0A= return ancestor.contains(element) && ancestor !=3D=3D element;=0A= =0A= while (element =3D element.parentNode)=0A= if (element =3D=3D ancestor) return true;=0A= =0A= return false;=0A= },=0A= =0A= scrollTo: function(element) {=0A= element =3D $(element);=0A= var pos =3D element.cumulativeOffset();=0A= window.scrollTo(pos[0], pos[1]);=0A= return element;=0A= },=0A= =0A= getStyle: function(element, style) {=0A= element =3D $(element);=0A= style =3D style =3D=3D 'float' ? 'cssFloat' : style.camelize();=0A= var value =3D element.style[style];=0A= if (!value || value =3D=3D 'auto') {=0A= var css =3D document.defaultView.getComputedStyle(element, null);=0A= value =3D css ? css[style] : null;=0A= }=0A= if (style =3D=3D 'opacity') return value ? parseFloat(value) : 1.0;=0A= return value =3D=3D 'auto' ? null : value;=0A= },=0A= =0A= getOpacity: function(element) {=0A= return $(element).getStyle('opacity');=0A= },=0A= =0A= setStyle: function(element, styles) {=0A= element =3D $(element);=0A= var elementStyle =3D element.style, match;=0A= if (Object.isString(styles)) {=0A= element.style.cssText +=3D ';' + styles;=0A= return styles.include('opacity') ?=0A= element.setOpacity(styles.match(/opacity:\s*(\d?\.?\d*)/)[1]) : = element;=0A= }=0A= for (var property in styles)=0A= if (property =3D=3D 'opacity') = element.setOpacity(styles[property]);=0A= else=0A= elementStyle[(property =3D=3D 'float' || property =3D=3D = 'cssFloat') ?=0A= (Object.isUndefined(elementStyle.styleFloat) ? 'cssFloat' : = 'styleFloat') :=0A= property] =3D styles[property];=0A= =0A= return element;=0A= },=0A= =0A= setOpacity: function(element, value) {=0A= element =3D $(element);=0A= element.style.opacity =3D (value =3D=3D 1 || value =3D=3D=3D '') ? = '' :=0A= (value < 0.00001) ? 0 : value;=0A= return element;=0A= },=0A= =0A= getDimensions: function(element) {=0A= element =3D $(element);=0A= var display =3D element.getStyle('display');=0A= if (display !=3D 'none' && display !=3D null) // Safari bug=0A= return {width: element.offsetWidth, height: element.offsetHeight};=0A= =0A= // All *Width and *Height properties give 0 on elements with display = none,=0A= // so enable the element temporarily=0A= var els =3D element.style;=0A= var originalVisibility =3D els.visibility;=0A= var originalPosition =3D els.position;=0A= var originalDisplay =3D els.display;=0A= els.visibility =3D 'hidden';=0A= els.position =3D 'absolute';=0A= els.display =3D 'block';=0A= var originalWidth =3D element.clientWidth;=0A= var originalHeight =3D element.clientHeight;=0A= els.display =3D originalDisplay;=0A= els.position =3D originalPosition;=0A= els.visibility =3D originalVisibility;=0A= return {width: originalWidth, height: originalHeight};=0A= },=0A= =0A= makePositioned: function(element) {=0A= element =3D $(element);=0A= var pos =3D Element.getStyle(element, 'position');=0A= if (pos =3D=3D 'static' || !pos) {=0A= element._madePositioned =3D true;=0A= element.style.position =3D 'relative';=0A= // Opera returns the offset relative to the positioning context, = when an=0A= // element is position relative but top and left have not been = defined=0A= if (Prototype.Browser.Opera) {=0A= element.style.top =3D 0;=0A= element.style.left =3D 0;=0A= }=0A= }=0A= return element;=0A= },=0A= =0A= undoPositioned: function(element) {=0A= element =3D $(element);=0A= if (element._madePositioned) {=0A= element._madePositioned =3D undefined;=0A= element.style.position =3D=0A= element.style.top =3D=0A= element.style.left =3D=0A= element.style.bottom =3D=0A= element.style.right =3D '';=0A= }=0A= return element;=0A= },=0A= =0A= makeClipping: function(element) {=0A= element =3D $(element);=0A= if (element._overflow) return element;=0A= element._overflow =3D Element.getStyle(element, 'overflow') || = 'auto';=0A= if (element._overflow !=3D=3D 'hidden')=0A= element.style.overflow =3D 'hidden';=0A= return element;=0A= },=0A= =0A= undoClipping: function(element) {=0A= element =3D $(element);=0A= if (!element._overflow) return element;=0A= element.style.overflow =3D element._overflow =3D=3D 'auto' ? '' : = element._overflow;=0A= element._overflow =3D null;=0A= return element;=0A= },=0A= =0A= cumulativeOffset: function(element) {=0A= var valueT =3D 0, valueL =3D 0;=0A= do {=0A= valueT +=3D element.offsetTop || 0;=0A= valueL +=3D element.offsetLeft || 0;=0A= element =3D element.offsetParent;=0A= } while (element);=0A= return Element._returnOffset(valueL, valueT);=0A= },=0A= =0A= positionedOffset: function(element) {=0A= var valueT =3D 0, valueL =3D 0;=0A= do {=0A= valueT +=3D element.offsetTop || 0;=0A= valueL +=3D element.offsetLeft || 0;=0A= element =3D element.offsetParent;=0A= if (element) {=0A= if (element.tagName.toUpperCase() =3D=3D 'BODY') break;=0A= var p =3D Element.getStyle(element, 'position');=0A= if (p !=3D=3D 'static') break;=0A= }=0A= } while (element);=0A= return Element._returnOffset(valueL, valueT);=0A= },=0A= =0A= absolutize: function(element) {=0A= element =3D $(element);=0A= if (element.getStyle('position') =3D=3D 'absolute') return element;=0A= // Position.prepare(); // To be done manually by Scripty when it = needs it.=0A= =0A= var offsets =3D element.positionedOffset();=0A= var top =3D offsets[1];=0A= var left =3D offsets[0];=0A= var width =3D element.clientWidth;=0A= var height =3D element.clientHeight;=0A= =0A= element._originalLeft =3D left - parseFloat(element.style.left || = 0);=0A= element._originalTop =3D top - parseFloat(element.style.top || = 0);=0A= element._originalWidth =3D element.style.width;=0A= element._originalHeight =3D element.style.height;=0A= =0A= element.style.position =3D 'absolute';=0A= element.style.top =3D top + 'px';=0A= element.style.left =3D left + 'px';=0A= element.style.width =3D width + 'px';=0A= element.style.height =3D height + 'px';=0A= return element;=0A= },=0A= =0A= relativize: function(element) {=0A= element =3D $(element);=0A= if (element.getStyle('position') =3D=3D 'relative') return element;=0A= // Position.prepare(); // To be done manually by Scripty when it = needs it.=0A= =0A= element.style.position =3D 'relative';=0A= var top =3D parseFloat(element.style.top || 0) - = (element._originalTop || 0);=0A= var left =3D parseFloat(element.style.left || 0) - = (element._originalLeft || 0);=0A= =0A= element.style.top =3D top + 'px';=0A= element.style.left =3D left + 'px';=0A= element.style.height =3D element._originalHeight;=0A= element.style.width =3D element._originalWidth;=0A= return element;=0A= },=0A= =0A= cumulativeScrollOffset: function(element) {=0A= var valueT =3D 0, valueL =3D 0;=0A= do {=0A= valueT +=3D element.scrollTop || 0;=0A= valueL +=3D element.scrollLeft || 0;=0A= element =3D element.parentNode;=0A= } while (element);=0A= return Element._returnOffset(valueL, valueT);=0A= },=0A= =0A= getOffsetParent: function(element) {=0A= if (element.offsetParent) return $(element.offsetParent);=0A= if (element =3D=3D document.body) return $(element);=0A= =0A= while ((element =3D element.parentNode) && element !=3D = document.body)=0A= if (Element.getStyle(element, 'position') !=3D 'static')=0A= return $(element);=0A= =0A= return $(document.body);=0A= },=0A= =0A= viewportOffset: function(forElement) {=0A= var valueT =3D 0, valueL =3D 0;=0A= =0A= var element =3D forElement;=0A= do {=0A= valueT +=3D element.offsetTop || 0;=0A= valueL +=3D element.offsetLeft || 0;=0A= =0A= // Safari fix=0A= if (element.offsetParent =3D=3D document.body &&=0A= Element.getStyle(element, 'position') =3D=3D 'absolute') break;=0A= =0A= } while (element =3D element.offsetParent);=0A= =0A= element =3D forElement;=0A= do {=0A= if (!Prototype.Browser.Opera || (element.tagName && = (element.tagName.toUpperCase() =3D=3D 'BODY'))) {=0A= valueT -=3D element.scrollTop || 0;=0A= valueL -=3D element.scrollLeft || 0;=0A= }=0A= } while (element =3D element.parentNode);=0A= =0A= return Element._returnOffset(valueL, valueT);=0A= },=0A= =0A= clonePosition: function(element, source) {=0A= var options =3D Object.extend({=0A= setLeft: true,=0A= setTop: true,=0A= setWidth: true,=0A= setHeight: true,=0A= offsetTop: 0,=0A= offsetLeft: 0=0A= }, arguments[2] || { });=0A= =0A= // find page position of source=0A= source =3D $(source);=0A= var p =3D source.viewportOffset();=0A= =0A= // find coordinate system to use=0A= element =3D $(element);=0A= var delta =3D [0, 0];=0A= var parent =3D null;=0A= // delta [0,0] will do fine with position: fixed elements,=0A= // position:absolute needs offsetParent deltas=0A= if (Element.getStyle(element, 'position') =3D=3D 'absolute') {=0A= parent =3D element.getOffsetParent();=0A= delta =3D parent.viewportOffset();=0A= }=0A= =0A= // correct by body offsets (fixes Safari)=0A= if (parent =3D=3D document.body) {=0A= delta[0] -=3D document.body.offsetLeft;=0A= delta[1] -=3D document.body.offsetTop;=0A= }=0A= =0A= // set position=0A= if (options.setLeft) element.style.left =3D (p[0] - delta[0] + = options.offsetLeft) + 'px';=0A= if (options.setTop) element.style.top =3D (p[1] - delta[1] + = options.offsetTop) + 'px';=0A= if (options.setWidth) element.style.width =3D source.offsetWidth + = 'px';=0A= if (options.setHeight) element.style.height =3D source.offsetHeight = + 'px';=0A= return element;=0A= }=0A= };=0A= =0A= Element.Methods.identify.counter =3D 1;=0A= =0A= Object.extend(Element.Methods, {=0A= getElementsBySelector: Element.Methods.select,=0A= childElements: Element.Methods.immediateDescendants=0A= });=0A= =0A= Element._attributeTranslations =3D {=0A= write: {=0A= names: {=0A= className: 'class',=0A= htmlFor: 'for'=0A= },=0A= values: { }=0A= }=0A= };=0A= =0A= if (Prototype.Browser.Opera) {=0A= Element.Methods.getStyle =3D Element.Methods.getStyle.wrap(=0A= function(proceed, element, style) {=0A= switch (style) {=0A= case 'left': case 'top': case 'right': case 'bottom':=0A= if (proceed(element, 'position') =3D=3D=3D 'static') return = null;=0A= case 'height': case 'width':=0A= // returns '0px' for hidden elements; we want it to return null=0A= if (!Element.visible(element)) return null;=0A= =0A= // returns the border-box dimensions rather than the = content-box=0A= // dimensions, so we subtract padding and borders from the = value=0A= var dim =3D parseInt(proceed(element, style), 10);=0A= =0A= if (dim !=3D=3D element['offset' + style.capitalize()])=0A= return dim + 'px';=0A= =0A= var properties;=0A= if (style =3D=3D=3D 'height') {=0A= properties =3D ['border-top-width', 'padding-top',=0A= 'padding-bottom', 'border-bottom-width'];=0A= }=0A= else {=0A= properties =3D ['border-left-width', 'padding-left',=0A= 'padding-right', 'border-right-width'];=0A= }=0A= return properties.inject(dim, function(memo, property) {=0A= var val =3D proceed(element, property);=0A= return val =3D=3D=3D null ? memo : memo - parseInt(val, 10);=0A= }) + 'px';=0A= default: return proceed(element, style);=0A= }=0A= }=0A= );=0A= =0A= Element.Methods.readAttribute =3D Element.Methods.readAttribute.wrap(=0A= function(proceed, element, attribute) {=0A= if (attribute =3D=3D=3D 'title') return element.title;=0A= return proceed(element, attribute);=0A= }=0A= );=0A= }=0A= =0A= else if (Prototype.Browser.IE) {=0A= // IE doesn't report offsets correctly for static elements, so we = change them=0A= // to "relative" to get the values, then change them back.=0A= Element.Methods.getOffsetParent =3D = Element.Methods.getOffsetParent.wrap(=0A= function(proceed, element) {=0A= element =3D $(element);=0A= // IE throws an error if element is not in document=0A= try { element.offsetParent }=0A= catch(e) { return $(document.body) }=0A= var position =3D element.getStyle('position');=0A= if (position !=3D=3D 'static') return proceed(element);=0A= element.setStyle({ position: 'relative' });=0A= var value =3D proceed(element);=0A= element.setStyle({ position: position });=0A= return value;=0A= }=0A= );=0A= =0A= $w('positionedOffset viewportOffset').each(function(method) {=0A= Element.Methods[method] =3D Element.Methods[method].wrap(=0A= function(proceed, element) {=0A= element =3D $(element);=0A= try { element.offsetParent }=0A= catch(e) { return Element._returnOffset(0,0) }=0A= var position =3D element.getStyle('position');=0A= if (position !=3D=3D 'static') return proceed(element);=0A= // Trigger hasLayout on the offset parent so that IE6 reports=0A= // accurate offsetTop and offsetLeft values for position: fixed.=0A= var offsetParent =3D element.getOffsetParent();=0A= if (offsetParent && offsetParent.getStyle('position') =3D=3D=3D = 'fixed')=0A= offsetParent.setStyle({ zoom: 1 });=0A= element.setStyle({ position: 'relative' });=0A= var value =3D proceed(element);=0A= element.setStyle({ position: position });=0A= return value;=0A= }=0A= );=0A= });=0A= =0A= Element.Methods.cumulativeOffset =3D = Element.Methods.cumulativeOffset.wrap(=0A= function(proceed, element) {=0A= try { element.offsetParent }=0A= catch(e) { return Element._returnOffset(0,0) }=0A= return proceed(element);=0A= }=0A= );=0A= =0A= Element.Methods.getStyle =3D function(element, style) {=0A= element =3D $(element);=0A= style =3D (style =3D=3D 'float' || style =3D=3D 'cssFloat') ? = 'styleFloat' : style.camelize();=0A= var value =3D element.style[style];=0A= if (!value && element.currentStyle) value =3D = element.currentStyle[style];=0A= =0A= if (style =3D=3D 'opacity') {=0A= if (value =3D (element.getStyle('filter') || = '').match(/alpha\(opacity=3D(.*)\)/))=0A= if (value[1]) return parseFloat(value[1]) / 100;=0A= return 1.0;=0A= }=0A= =0A= if (value =3D=3D 'auto') {=0A= if ((style =3D=3D 'width' || style =3D=3D 'height') && = (element.getStyle('display') !=3D 'none'))=0A= return element['offset' + style.capitalize()] + 'px';=0A= return null;=0A= }=0A= return value;=0A= };=0A= =0A= Element.Methods.setOpacity =3D function(element, value) {=0A= function stripAlpha(filter){=0A= return filter.replace(/alpha\([^\)]*\)/gi,'');=0A= }=0A= element =3D $(element);=0A= var currentStyle =3D element.currentStyle;=0A= if ((currentStyle && !currentStyle.hasLayout) ||=0A= (!currentStyle && element.style.zoom =3D=3D 'normal'))=0A= element.style.zoom =3D 1;=0A= =0A= var filter =3D element.getStyle('filter'), style =3D element.style;=0A= if (value =3D=3D 1 || value =3D=3D=3D '') {=0A= (filter =3D stripAlpha(filter)) ?=0A= style.filter =3D filter : style.removeAttribute('filter');=0A= return element;=0A= } else if (value < 0.00001) value =3D 0;=0A= style.filter =3D stripAlpha(filter) +=0A= 'alpha(opacity=3D' + (value * 100) + ')';=0A= return element;=0A= };=0A= =0A= Element._attributeTranslations =3D {=0A= read: {=0A= names: {=0A= 'class': 'className',=0A= 'for': 'htmlFor'=0A= },=0A= values: {=0A= _getAttr: function(element, attribute) {=0A= return element.getAttribute(attribute, 2);=0A= },=0A= _getAttrNode: function(element, attribute) {=0A= var node =3D element.getAttributeNode(attribute);=0A= return node ? node.value : "";=0A= },=0A= _getEv: function(element, attribute) {=0A= attribute =3D element.getAttribute(attribute);=0A= return attribute ? attribute.toString().slice(23, -2) : null;=0A= },=0A= _flag: function(element, attribute) {=0A= return $(element).hasAttribute(attribute) ? attribute : null;=0A= },=0A= style: function(element) {=0A= return element.style.cssText.toLowerCase();=0A= },=0A= title: function(element) {=0A= return element.title;=0A= }=0A= }=0A= }=0A= };=0A= =0A= Element._attributeTranslations.write =3D {=0A= names: Object.extend({=0A= cellpadding: 'cellPadding',=0A= cellspacing: 'cellSpacing'=0A= }, Element._attributeTranslations.read.names),=0A= values: {=0A= checked: function(element, value) {=0A= element.checked =3D !!value;=0A= },=0A= =0A= style: function(element, value) {=0A= element.style.cssText =3D value ? value : '';=0A= }=0A= }=0A= };=0A= =0A= Element._attributeTranslations.has =3D {};=0A= =0A= $w('colSpan rowSpan vAlign dateTime accessKey tabIndex ' +=0A= 'encType maxLength readOnly longDesc = frameBorder').each(function(attr) {=0A= Element._attributeTranslations.write.names[attr.toLowerCase()] =3D = attr;=0A= Element._attributeTranslations.has[attr.toLowerCase()] =3D attr;=0A= });=0A= =0A= (function(v) {=0A= Object.extend(v, {=0A= href: v._getAttr,=0A= src: v._getAttr,=0A= type: v._getAttr,=0A= action: v._getAttrNode,=0A= disabled: v._flag,=0A= checked: v._flag,=0A= readonly: v._flag,=0A= multiple: v._flag,=0A= onload: v._getEv,=0A= onunload: v._getEv,=0A= onclick: v._getEv,=0A= ondblclick: v._getEv,=0A= onmousedown: v._getEv,=0A= onmouseup: v._getEv,=0A= onmouseover: v._getEv,=0A= onmousemove: v._getEv,=0A= onmouseout: v._getEv,=0A= onfocus: v._getEv,=0A= onblur: v._getEv,=0A= onkeypress: v._getEv,=0A= onkeydown: v._getEv,=0A= onkeyup: v._getEv,=0A= onsubmit: v._getEv,=0A= onreset: v._getEv,=0A= onselect: v._getEv,=0A= onchange: v._getEv=0A= });=0A= })(Element._attributeTranslations.read.values);=0A= }=0A= =0A= else if (Prototype.Browser.Gecko && = /rv:1\.8\.0/.test(navigator.userAgent)) {=0A= Element.Methods.setOpacity =3D function(element, value) {=0A= element =3D $(element);=0A= element.style.opacity =3D (value =3D=3D 1) ? 0.999999 :=0A= (value =3D=3D=3D '') ? '' : (value < 0.00001) ? 0 : value;=0A= return element;=0A= };=0A= }=0A= =0A= else if (Prototype.Browser.WebKit) {=0A= Element.Methods.setOpacity =3D function(element, value) {=0A= element =3D $(element);=0A= element.style.opacity =3D (value =3D=3D 1 || value =3D=3D=3D '') ? = '' :=0A= (value < 0.00001) ? 0 : value;=0A= =0A= if (value =3D=3D 1)=0A= if(element.tagName.toUpperCase() =3D=3D 'IMG' && element.width) {=0A= element.width++; element.width--;=0A= } else try {=0A= var n =3D document.createTextNode(' ');=0A= element.appendChild(n);=0A= element.removeChild(n);=0A= } catch (e) { }=0A= =0A= return element;=0A= };=0A= =0A= // Safari returns margins on body which is incorrect if the child is = absolutely=0A= // positioned. For performance reasons, redefine = Element#cumulativeOffset for=0A= // KHTML/WebKit only.=0A= Element.Methods.cumulativeOffset =3D function(element) {=0A= var valueT =3D 0, valueL =3D 0;=0A= do {=0A= valueT +=3D element.offsetTop || 0;=0A= valueL +=3D element.offsetLeft || 0;=0A= if (element.offsetParent =3D=3D document.body)=0A= if (Element.getStyle(element, 'position') =3D=3D 'absolute') = break;=0A= =0A= element =3D element.offsetParent;=0A= } while (element);=0A= =0A= return Element._returnOffset(valueL, valueT);=0A= };=0A= }=0A= =0A= if (Prototype.Browser.IE || Prototype.Browser.Opera) {=0A= // IE and Opera are missing .innerHTML support for TABLE-related and = SELECT elements=0A= Element.Methods.update =3D function(element, content) {=0A= element =3D $(element);=0A= =0A= if (content && content.toElement) content =3D content.toElement();=0A= if (Object.isElement(content)) return = element.update().insert(content);=0A= =0A= content =3D Object.toHTML(content);=0A= var tagName =3D element.tagName.toUpperCase();=0A= =0A= if (tagName in Element._insertionTranslations.tags) {=0A= $A(element.childNodes).each(function(node) { = element.removeChild(node) });=0A= Element._getContentFromAnonymousElement(tagName, = content.stripScripts())=0A= .each(function(node) { element.appendChild(node) });=0A= }=0A= else element.innerHTML =3D content.stripScripts();=0A= =0A= content.evalScripts.bind(content).defer();=0A= return element;=0A= };=0A= }=0A= =0A= if ('outerHTML' in document.createElement('div')) {=0A= Element.Methods.replace =3D function(element, content) {=0A= element =3D $(element);=0A= =0A= if (content && content.toElement) content =3D content.toElement();=0A= if (Object.isElement(content)) {=0A= element.parentNode.replaceChild(content, element);=0A= return element;=0A= }=0A= =0A= content =3D Object.toHTML(content);=0A= var parent =3D element.parentNode, tagName =3D = parent.tagName.toUpperCase();=0A= =0A= if (Element._insertionTranslations.tags[tagName]) {=0A= var nextSibling =3D element.next();=0A= var fragments =3D Element._getContentFromAnonymousElement(tagName, = content.stripScripts());=0A= parent.removeChild(element);=0A= if (nextSibling)=0A= fragments.each(function(node) { parent.insertBefore(node, = nextSibling) });=0A= else=0A= fragments.each(function(node) { parent.appendChild(node) });=0A= }=0A= else element.outerHTML =3D content.stripScripts();=0A= =0A= content.evalScripts.bind(content).defer();=0A= return element;=0A= };=0A= }=0A= =0A= Element._returnOffset =3D function(l, t) {=0A= var result =3D [l, t];=0A= result.left =3D l;=0A= result.top =3D t;=0A= return result;=0A= };=0A= =0A= Element._getContentFromAnonymousElement =3D function(tagName, html) {=0A= var div =3D new Element('div'), t =3D = Element._insertionTranslations.tags[tagName];=0A= if (t) {=0A= div.innerHTML =3D t[0] + html + t[1];=0A= t[2].times(function() { div =3D div.firstChild });=0A= } else div.innerHTML =3D html;=0A= return $A(div.childNodes);=0A= };=0A= =0A= Element._insertionTranslations =3D {=0A= before: function(element, node) {=0A= element.parentNode.insertBefore(node, element);=0A= },=0A= top: function(element, node) {=0A= element.insertBefore(node, element.firstChild);=0A= },=0A= bottom: function(element, node) {=0A= element.appendChild(node);=0A= },=0A= after: function(element, node) {=0A= element.parentNode.insertBefore(node, element.nextSibling);=0A= },=0A= tags: {=0A= TABLE: ['', '
', 1],=0A= TBODY: ['', '
', 2],=0A= TR: ['', '
', 3],=0A= TD: ['
', '
', 4],=0A= SELECT: ['', 1]=0A= }=0A= };=0A= =0A= (function() {=0A= Object.extend(this.tags, {=0A= THEAD: this.tags.TBODY,=0A= TFOOT: this.tags.TBODY,=0A= TH: this.tags.TD=0A= });=0A= }).call(Element._insertionTranslations);=0A= =0A= Element.Methods.Simulated =3D {=0A= hasAttribute: function(element, attribute) {=0A= attribute =3D Element._attributeTranslations.has[attribute] || = attribute;=0A= var node =3D $(element).getAttributeNode(attribute);=0A= return !!(node && node.specified);=0A= }=0A= };=0A= =0A= Element.Methods.ByTag =3D { };=0A= =0A= Object.extend(Element, Element.Methods);=0A= =0A= if (!Prototype.BrowserFeatures.ElementExtensions &&=0A= document.createElement('div')['__proto__']) {=0A= window.HTMLElement =3D { };=0A= window.HTMLElement.prototype =3D = document.createElement('div')['__proto__'];=0A= Prototype.BrowserFeatures.ElementExtensions =3D true;=0A= }=0A= =0A= Element.extend =3D (function() {=0A= if (Prototype.BrowserFeatures.SpecificElementExtensions)=0A= return Prototype.K;=0A= =0A= var Methods =3D { }, ByTag =3D Element.Methods.ByTag;=0A= =0A= var extend =3D Object.extend(function(element) {=0A= if (!element || element._extendedByPrototype ||=0A= element.nodeType !=3D 1 || element =3D=3D window) return element;=0A= =0A= var methods =3D Object.clone(Methods),=0A= tagName =3D element.tagName.toUpperCase(), property, value;=0A= =0A= // extend methods for specific tags=0A= if (ByTag[tagName]) Object.extend(methods, ByTag[tagName]);=0A= =0A= for (property in methods) {=0A= value =3D methods[property];=0A= if (Object.isFunction(value) && !(property in element))=0A= element[property] =3D value.methodize();=0A= }=0A= =0A= element._extendedByPrototype =3D Prototype.emptyFunction;=0A= return element;=0A= =0A= }, {=0A= refresh: function() {=0A= // extend methods for all tags (Safari doesn't need this)=0A= if (!Prototype.BrowserFeatures.ElementExtensions) {=0A= Object.extend(Methods, Element.Methods);=0A= Object.extend(Methods, Element.Methods.Simulated);=0A= }=0A= }=0A= });=0A= =0A= extend.refresh();=0A= return extend;=0A= })();=0A= =0A= Element.hasAttribute =3D function(element, attribute) {=0A= if (element.hasAttribute) return element.hasAttribute(attribute);=0A= return Element.Methods.Simulated.hasAttribute(element, attribute);=0A= };=0A= =0A= Element.addMethods =3D function(methods) {=0A= var F =3D Prototype.BrowserFeatures, T =3D Element.Methods.ByTag;=0A= =0A= if (!methods) {=0A= Object.extend(Form, Form.Methods);=0A= Object.extend(Form.Element, Form.Element.Methods);=0A= Object.extend(Element.Methods.ByTag, {=0A= "FORM": Object.clone(Form.Methods),=0A= "INPUT": Object.clone(Form.Element.Methods),=0A= "SELECT": Object.clone(Form.Element.Methods),=0A= "TEXTAREA": Object.clone(Form.Element.Methods)=0A= });=0A= }=0A= =0A= if (arguments.length =3D=3D 2) {=0A= var tagName =3D methods;=0A= methods =3D arguments[1];=0A= }=0A= =0A= if (!tagName) Object.extend(Element.Methods, methods || { });=0A= else {=0A= if (Object.isArray(tagName)) tagName.each(extend);=0A= else extend(tagName);=0A= }=0A= =0A= function extend(tagName) {=0A= tagName =3D tagName.toUpperCase();=0A= if (!Element.Methods.ByTag[tagName])=0A= Element.Methods.ByTag[tagName] =3D { };=0A= Object.extend(Element.Methods.ByTag[tagName], methods);=0A= }=0A= =0A= function copy(methods, destination, onlyIfAbsent) {=0A= onlyIfAbsent =3D onlyIfAbsent || false;=0A= for (var property in methods) {=0A= var value =3D methods[property];=0A= if (!Object.isFunction(value)) continue;=0A= if (!onlyIfAbsent || !(property in destination))=0A= destination[property] =3D value.methodize();=0A= }=0A= }=0A= =0A= function findDOMClass(tagName) {=0A= var klass;=0A= var trans =3D {=0A= "OPTGROUP": "OptGroup", "TEXTAREA": "TextArea", "P": "Paragraph",=0A= "FIELDSET": "FieldSet", "UL": "UList", "OL": "OList", "DL": = "DList",=0A= "DIR": "Directory", "H1": "Heading", "H2": "Heading", "H3": = "Heading",=0A= "H4": "Heading", "H5": "Heading", "H6": "Heading", "Q": "Quote",=0A= "INS": "Mod", "DEL": "Mod", "A": "Anchor", "IMG": "Image", = "CAPTION":=0A= "TableCaption", "COL": "TableCol", "COLGROUP": "TableCol", "THEAD":=0A= "TableSection", "TFOOT": "TableSection", "TBODY": "TableSection", = "TR":=0A= "TableRow", "TH": "TableCell", "TD": "TableCell", "FRAMESET":=0A= "FrameSet", "IFRAME": "IFrame"=0A= };=0A= if (trans[tagName]) klass =3D 'HTML' + trans[tagName] + 'Element';=0A= if (window[klass]) return window[klass];=0A= klass =3D 'HTML' + tagName + 'Element';=0A= if (window[klass]) return window[klass];=0A= klass =3D 'HTML' + tagName.capitalize() + 'Element';=0A= if (window[klass]) return window[klass];=0A= =0A= window[klass] =3D { };=0A= window[klass].prototype =3D = document.createElement(tagName)['__proto__'];=0A= return window[klass];=0A= }=0A= =0A= if (F.ElementExtensions) {=0A= copy(Element.Methods, HTMLElement.prototype);=0A= copy(Element.Methods.Simulated, HTMLElement.prototype, true);=0A= }=0A= =0A= if (F.SpecificElementExtensions) {=0A= for (var tag in Element.Methods.ByTag) {=0A= var klass =3D findDOMClass(tag);=0A= if (Object.isUndefined(klass)) continue;=0A= copy(T[tag], klass.prototype);=0A= }=0A= }=0A= =0A= Object.extend(Element, Element.Methods);=0A= delete Element.ByTag;=0A= =0A= if (Element.extend.refresh) Element.extend.refresh();=0A= Element.cache =3D { };=0A= };=0A= =0A= document.viewport =3D {=0A= getDimensions: function() {=0A= var dimensions =3D { }, B =3D Prototype.Browser;=0A= $w('width height').each(function(d) {=0A= var D =3D d.capitalize();=0A= if (B.WebKit && !document.evaluate) {=0A= // Safari <3.0 needs self.innerWidth/Height=0A= dimensions[d] =3D self['inner' + D];=0A= } else if (B.Opera && parseFloat(window.opera.version()) < 9.5) {=0A= // Opera <9.5 needs document.body.clientWidth/Height=0A= dimensions[d] =3D document.body['client' + D]=0A= } else {=0A= dimensions[d] =3D document.documentElement['client' + D];=0A= }=0A= });=0A= return dimensions;=0A= },=0A= =0A= getWidth: function() {=0A= return this.getDimensions().width;=0A= },=0A= =0A= getHeight: function() {=0A= return this.getDimensions().height;=0A= },=0A= =0A= getScrollOffsets: function() {=0A= return Element._returnOffset(=0A= window.pageXOffset || document.documentElement.scrollLeft || = document.body.scrollLeft,=0A= window.pageYOffset || document.documentElement.scrollTop || = document.body.scrollTop);=0A= }=0A= };=0A= /* Portions of the Selector class are derived from Jack Slocum's = DomQuery,=0A= * part of YUI-Ext version 0.40, distributed under the terms of an = MIT-style=0A= * license. Please see http://www.yui-ext.com/ for more information. */=0A= =0A= var Selector =3D Class.create({=0A= initialize: function(expression) {=0A= this.expression =3D expression.strip();=0A= =0A= if (this.shouldUseSelectorsAPI()) {=0A= this.mode =3D 'selectorsAPI';=0A= } else if (this.shouldUseXPath()) {=0A= this.mode =3D 'xpath';=0A= this.compileXPathMatcher();=0A= } else {=0A= this.mode =3D "normal";=0A= this.compileMatcher();=0A= }=0A= =0A= },=0A= =0A= shouldUseXPath: function() {=0A= if (!Prototype.BrowserFeatures.XPath) return false;=0A= =0A= var e =3D this.expression;=0A= =0A= // Safari 3 chokes on :*-of-type and :empty=0A= if (Prototype.Browser.WebKit &&=0A= (e.include("-of-type") || e.include(":empty")))=0A= return false;=0A= =0A= // XPath can't do namespaced attributes, nor can it read=0A= // the "checked" property from DOM nodes=0A= if ((/(\[[\w-]*?:|:checked)/).test(e))=0A= return false;=0A= =0A= return true;=0A= },=0A= =0A= shouldUseSelectorsAPI: function() {=0A= if (!Prototype.BrowserFeatures.SelectorsAPI) return false;=0A= =0A= if (!Selector._div) Selector._div =3D new Element('div');=0A= =0A= // Make sure the browser treats the selector as valid. Test on an=0A= // isolated element to minimize cost of this check.=0A= try {=0A= Selector._div.querySelector(this.expression);=0A= } catch(e) {=0A= return false;=0A= }=0A= =0A= return true;=0A= },=0A= =0A= compileMatcher: function() {=0A= var e =3D this.expression, ps =3D Selector.patterns, h =3D = Selector.handlers,=0A= c =3D Selector.criteria, le, p, m;=0A= =0A= if (Selector._cache[e]) {=0A= this.matcher =3D Selector._cache[e];=0A= return;=0A= }=0A= =0A= this.matcher =3D ["this.matcher =3D function(root) {",=0A= "var r =3D root, h =3D Selector.handlers, c =3D = false, n;"];=0A= =0A= while (e && le !=3D e && (/\S/).test(e)) {=0A= le =3D e;=0A= for (var i in ps) {=0A= p =3D ps[i];=0A= if (m =3D e.match(p)) {=0A= this.matcher.push(Object.isFunction(c[i]) ? c[i](m) :=0A= new Template(c[i]).evaluate(m));=0A= e =3D e.replace(m[0], '');=0A= break;=0A= }=0A= }=0A= }=0A= =0A= this.matcher.push("return h.unique(n);\n}");=0A= eval(this.matcher.join('\n'));=0A= Selector._cache[this.expression] =3D this.matcher;=0A= },=0A= =0A= compileXPathMatcher: function() {=0A= var e =3D this.expression, ps =3D Selector.patterns,=0A= x =3D Selector.xpath, le, m;=0A= =0A= if (Selector._cache[e]) {=0A= this.xpath =3D Selector._cache[e]; return;=0A= }=0A= =0A= this.matcher =3D ['.//*'];=0A= while (e && le !=3D e && (/\S/).test(e)) {=0A= le =3D e;=0A= for (var i in ps) {=0A= if (m =3D e.match(ps[i])) {=0A= this.matcher.push(Object.isFunction(x[i]) ? x[i](m) :=0A= new Template(x[i]).evaluate(m));=0A= e =3D e.replace(m[0], '');=0A= break;=0A= }=0A= }=0A= }=0A= =0A= this.xpath =3D this.matcher.join('');=0A= Selector._cache[this.expression] =3D this.xpath;=0A= },=0A= =0A= findElements: function(root) {=0A= root =3D root || document;=0A= var e =3D this.expression, results;=0A= =0A= switch (this.mode) {=0A= case 'selectorsAPI':=0A= // querySelectorAll queries document-wide, then filters to = descendants=0A= // of the context element. That's not what we want.=0A= // Add an explicit context to the selector if necessary.=0A= if (root !=3D=3D document) {=0A= var oldId =3D root.id, id =3D $(root).identify();=0A= e =3D "#" + id + " " + e;=0A= }=0A= =0A= results =3D $A(root.querySelectorAll(e)).map(Element.extend);=0A= root.id =3D oldId;=0A= =0A= return results;=0A= case 'xpath':=0A= return document._getElementsByXPath(this.xpath, root);=0A= default:=0A= return this.matcher(root);=0A= }=0A= },=0A= =0A= match: function(element) {=0A= this.tokens =3D [];=0A= =0A= var e =3D this.expression, ps =3D Selector.patterns, as =3D = Selector.assertions;=0A= var le, p, m;=0A= =0A= while (e && le !=3D=3D e && (/\S/).test(e)) {=0A= le =3D e;=0A= for (var i in ps) {=0A= p =3D ps[i];=0A= if (m =3D e.match(p)) {=0A= // use the Selector.assertions methods unless the selector=0A= // is too complex.=0A= if (as[i]) {=0A= this.tokens.push([i, Object.clone(m)]);=0A= e =3D e.replace(m[0], '');=0A= } else {=0A= // reluctantly do a document-wide search=0A= // and look for a match in the array=0A= return this.findElements(document).include(element);=0A= }=0A= }=0A= }=0A= }=0A= =0A= var match =3D true, name, matches;=0A= for (var i =3D 0, token; token =3D this.tokens[i]; i++) {=0A= name =3D token[0], matches =3D token[1];=0A= if (!Selector.assertions[name](element, matches)) {=0A= match =3D false; break;=0A= }=0A= }=0A= =0A= return match;=0A= },=0A= =0A= toString: function() {=0A= return this.expression;=0A= },=0A= =0A= inspect: function() {=0A= return "#";=0A= }=0A= });=0A= =0A= Object.extend(Selector, {=0A= _cache: { },=0A= =0A= xpath: {=0A= descendant: "//*",=0A= child: "/*",=0A= adjacent: "/following-sibling::*[1]",=0A= laterSibling: '/following-sibling::*',=0A= tagName: function(m) {=0A= if (m[1] =3D=3D '*') return '';=0A= return "[local-name()=3D'" + m[1].toLowerCase() +=0A= "' or local-name()=3D'" + m[1].toUpperCase() + "']";=0A= },=0A= className: "[contains(concat(' ', @class, ' '), ' #{1} ')]",=0A= id: "[@id=3D'#{1}']",=0A= attrPresence: function(m) {=0A= m[1] =3D m[1].toLowerCase();=0A= return new Template("[@#{1}]").evaluate(m);=0A= },=0A= attr: function(m) {=0A= m[1] =3D m[1].toLowerCase();=0A= m[3] =3D m[5] || m[6];=0A= return new Template(Selector.xpath.operators[m[2]]).evaluate(m);=0A= },=0A= pseudo: function(m) {=0A= var h =3D Selector.xpath.pseudos[m[1]];=0A= if (!h) return '';=0A= if (Object.isFunction(h)) return h(m);=0A= return new Template(Selector.xpath.pseudos[m[1]]).evaluate(m);=0A= },=0A= operators: {=0A= '=3D': "[@#{1}=3D'#{3}']",=0A= '!=3D': "[@#{1}!=3D'#{3}']",=0A= '^=3D': "[starts-with(@#{1}, '#{3}')]",=0A= '$=3D': "[substring(@#{1}, (string-length(@#{1}) - = string-length('#{3}') + 1))=3D'#{3}']",=0A= '*=3D': "[contains(@#{1}, '#{3}')]",=0A= '~=3D': "[contains(concat(' ', @#{1}, ' '), ' #{3} ')]",=0A= '|=3D': "[contains(concat('-', @#{1}, '-'), '-#{3}-')]"=0A= },=0A= pseudos: {=0A= 'first-child': '[not(preceding-sibling::*)]',=0A= 'last-child': '[not(following-sibling::*)]',=0A= 'only-child': '[not(preceding-sibling::* or = following-sibling::*)]',=0A= 'empty': "[count(*) =3D 0 and (count(text()) =3D 0)]",=0A= 'checked': "[@checked]",=0A= 'disabled': "[(@disabled) and (@type!=3D'hidden')]",=0A= 'enabled': "[not(@disabled) and (@type!=3D'hidden')]",=0A= 'not': function(m) {=0A= var e =3D m[6], p =3D Selector.patterns,=0A= x =3D Selector.xpath, le, v;=0A= =0A= var exclusion =3D [];=0A= while (e && le !=3D e && (/\S/).test(e)) {=0A= le =3D e;=0A= for (var i in p) {=0A= if (m =3D e.match(p[i])) {=0A= v =3D Object.isFunction(x[i]) ? x[i](m) : new = Template(x[i]).evaluate(m);=0A= exclusion.push("(" + v.substring(1, v.length - 1) + ")");=0A= e =3D e.replace(m[0], '');=0A= break;=0A= }=0A= }=0A= }=0A= return "[not(" + exclusion.join(" and ") + ")]";=0A= },=0A= 'nth-child': function(m) {=0A= return = Selector.xpath.pseudos.nth("(count(./preceding-sibling::*) + 1) ", m);=0A= },=0A= 'nth-last-child': function(m) {=0A= return = Selector.xpath.pseudos.nth("(count(./following-sibling::*) + 1) ", m);=0A= },=0A= 'nth-of-type': function(m) {=0A= return Selector.xpath.pseudos.nth("position() ", m);=0A= },=0A= 'nth-last-of-type': function(m) {=0A= return Selector.xpath.pseudos.nth("(last() + 1 - position()) ", = m);=0A= },=0A= 'first-of-type': function(m) {=0A= m[6] =3D "1"; return Selector.xpath.pseudos['nth-of-type'](m);=0A= },=0A= 'last-of-type': function(m) {=0A= m[6] =3D "1"; return = Selector.xpath.pseudos['nth-last-of-type'](m);=0A= },=0A= 'only-of-type': function(m) {=0A= var p =3D Selector.xpath.pseudos; return p['first-of-type'](m) + = p['last-of-type'](m);=0A= },=0A= nth: function(fragment, m) {=0A= var mm, formula =3D m[6], predicate;=0A= if (formula =3D=3D 'even') formula =3D '2n+0';=0A= if (formula =3D=3D 'odd') formula =3D '2n+1';=0A= if (mm =3D formula.match(/^(\d+)$/)) // digit only=0A= return '[' + fragment + "=3D " + mm[1] + ']';=0A= if (mm =3D formula.match(/^(-?\d*)?n(([+-])(\d+))?/)) { // an+b=0A= if (mm[1] =3D=3D "-") mm[1] =3D -1;=0A= var a =3D mm[1] ? Number(mm[1]) : 1;=0A= var b =3D mm[2] ? Number(mm[2]) : 0;=0A= predicate =3D "[((#{fragment} - #{b}) mod #{a} =3D 0) and " +=0A= "((#{fragment} - #{b}) div #{a} >=3D 0)]";=0A= return new Template(predicate).evaluate({=0A= fragment: fragment, a: a, b: b });=0A= }=0A= }=0A= }=0A= },=0A= =0A= criteria: {=0A= tagName: 'n =3D h.tagName(n, r, "#{1}", c); c =3D false;',=0A= className: 'n =3D h.className(n, r, "#{1}", c); c =3D false;',=0A= id: 'n =3D h.id(n, r, "#{1}", c); c =3D false;',=0A= attrPresence: 'n =3D h.attrPresence(n, r, "#{1}", c); c =3D false;',=0A= attr: function(m) {=0A= m[3] =3D (m[5] || m[6]);=0A= return new Template('n =3D h.attr(n, r, "#{1}", "#{3}", "#{2}", = c); c =3D false;').evaluate(m);=0A= },=0A= pseudo: function(m) {=0A= if (m[6]) m[6] =3D m[6].replace(/"/g, '\\"');=0A= return new Template('n =3D h.pseudo(n, "#{1}", "#{6}", r, c); c = =3D false;').evaluate(m);=0A= },=0A= descendant: 'c =3D "descendant";',=0A= child: 'c =3D "child";',=0A= adjacent: 'c =3D "adjacent";',=0A= laterSibling: 'c =3D "laterSibling";'=0A= },=0A= =0A= patterns: {=0A= // combinators must be listed first=0A= // (and descendant needs to be last combinator)=0A= laterSibling: /^\s*~\s*/,=0A= child: /^\s*>\s*/,=0A= adjacent: /^\s*\+\s*/,=0A= descendant: /^\s/,=0A= =0A= // selectors follow=0A= tagName: /^\s*(\*|[\w\-]+)(\b|$)?/,=0A= id: /^#([\w\-\*]+)(\b|$)/,=0A= className: /^\.([\w\-\*]+)(\b|$)/,=0A= pseudo:=0A= /^:((first|last|nth|nth-last|only)(-child|-of-type)|empty|checked|(en|dis= )abled|not)(\((.*?)\))?(\b|$|(?=3D\s|[:+~>]))/,=0A= attrPresence: /^\[((?:[\w]+:)?[\w]+)\]/,=0A= attr: = /\[((?:[\w-]*:)?[\w-]+)\s*(?:([!^$*~|]?=3D)\s*((['"])([^\4]*?)\4|([^'"][^= \]]*?)))?\]/=0A= },=0A= =0A= // for Selector.match and Element#match=0A= assertions: {=0A= tagName: function(element, matches) {=0A= return matches[1].toUpperCase() =3D=3D = element.tagName.toUpperCase();=0A= },=0A= =0A= className: function(element, matches) {=0A= return Element.hasClassName(element, matches[1]);=0A= },=0A= =0A= id: function(element, matches) {=0A= return element.id =3D=3D=3D matches[1];=0A= },=0A= =0A= attrPresence: function(element, matches) {=0A= return Element.hasAttribute(element, matches[1]);=0A= },=0A= =0A= attr: function(element, matches) {=0A= var nodeValue =3D Element.readAttribute(element, matches[1]);=0A= return nodeValue && Selector.operators[matches[2]](nodeValue, = matches[5] || matches[6]);=0A= }=0A= },=0A= =0A= handlers: {=0A= // UTILITY FUNCTIONS=0A= // joins two collections=0A= concat: function(a, b) {=0A= for (var i =3D 0, node; node =3D b[i]; i++)=0A= a.push(node);=0A= return a;=0A= },=0A= =0A= // marks an array of nodes for counting=0A= mark: function(nodes) {=0A= var _true =3D Prototype.emptyFunction;=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= node._countedByPrototype =3D _true;=0A= return nodes;=0A= },=0A= =0A= unmark: function(nodes) {=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= node._countedByPrototype =3D undefined;=0A= return nodes;=0A= },=0A= =0A= // mark each child node with its position (for nth calls)=0A= // "ofType" flag indicates whether we're indexing for nth-of-type=0A= // rather than nth-child=0A= index: function(parentNode, reverse, ofType) {=0A= parentNode._countedByPrototype =3D Prototype.emptyFunction;=0A= if (reverse) {=0A= for (var nodes =3D parentNode.childNodes, i =3D nodes.length - = 1, j =3D 1; i >=3D 0; i--) {=0A= var node =3D nodes[i];=0A= if (node.nodeType =3D=3D 1 && (!ofType || = node._countedByPrototype)) node.nodeIndex =3D j++;=0A= }=0A= } else {=0A= for (var i =3D 0, j =3D 1, nodes =3D parentNode.childNodes; node = =3D nodes[i]; i++)=0A= if (node.nodeType =3D=3D 1 && (!ofType || = node._countedByPrototype)) node.nodeIndex =3D j++;=0A= }=0A= },=0A= =0A= // filters out duplicates and extends all nodes=0A= unique: function(nodes) {=0A= if (nodes.length =3D=3D 0) return nodes;=0A= var results =3D [], n;=0A= for (var i =3D 0, l =3D nodes.length; i < l; i++)=0A= if (!(n =3D nodes[i])._countedByPrototype) {=0A= n._countedByPrototype =3D Prototype.emptyFunction;=0A= results.push(Element.extend(n));=0A= }=0A= return Selector.handlers.unmark(results);=0A= },=0A= =0A= // COMBINATOR FUNCTIONS=0A= descendant: function(nodes) {=0A= var h =3D Selector.handlers;=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A= h.concat(results, node.getElementsByTagName('*'));=0A= return results;=0A= },=0A= =0A= child: function(nodes) {=0A= var h =3D Selector.handlers;=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++) {=0A= for (var j =3D 0, child; child =3D node.childNodes[j]; j++)=0A= if (child.nodeType =3D=3D 1 && child.tagName !=3D '!') = results.push(child);=0A= }=0A= return results;=0A= },=0A= =0A= adjacent: function(nodes) {=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++) {=0A= var next =3D this.nextElementSibling(node);=0A= if (next) results.push(next);=0A= }=0A= return results;=0A= },=0A= =0A= laterSibling: function(nodes) {=0A= var h =3D Selector.handlers;=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A= h.concat(results, Element.nextSiblings(node));=0A= return results;=0A= },=0A= =0A= nextElementSibling: function(node) {=0A= while (node =3D node.nextSibling)=0A= if (node.nodeType =3D=3D 1) return node;=0A= return null;=0A= },=0A= =0A= previousElementSibling: function(node) {=0A= while (node =3D node.previousSibling)=0A= if (node.nodeType =3D=3D 1) return node;=0A= return null;=0A= },=0A= =0A= // TOKEN FUNCTIONS=0A= tagName: function(nodes, root, tagName, combinator) {=0A= var uTagName =3D tagName.toUpperCase();=0A= var results =3D [], h =3D Selector.handlers;=0A= if (nodes) {=0A= if (combinator) {=0A= // fastlane for ordinary descendant combinators=0A= if (combinator =3D=3D "descendant") {=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= h.concat(results, node.getElementsByTagName(tagName));=0A= return results;=0A= } else nodes =3D this[combinator](nodes);=0A= if (tagName =3D=3D "*") return nodes;=0A= }=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= if (node.tagName.toUpperCase() =3D=3D=3D uTagName) = results.push(node);=0A= return results;=0A= } else return root.getElementsByTagName(tagName);=0A= },=0A= =0A= id: function(nodes, root, id, combinator) {=0A= var targetNode =3D $(id), h =3D Selector.handlers;=0A= if (!targetNode) return [];=0A= if (!nodes && root =3D=3D document) return [targetNode];=0A= if (nodes) {=0A= if (combinator) {=0A= if (combinator =3D=3D 'child') {=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= if (targetNode.parentNode =3D=3D node) return [targetNode];=0A= } else if (combinator =3D=3D 'descendant') {=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= if (Element.descendantOf(targetNode, node)) return = [targetNode];=0A= } else if (combinator =3D=3D 'adjacent') {=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= if (Selector.handlers.previousElementSibling(targetNode) = =3D=3D node)=0A= return [targetNode];=0A= } else nodes =3D h[combinator](nodes);=0A= }=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= if (node =3D=3D targetNode) return [targetNode];=0A= return [];=0A= }=0A= return (targetNode && Element.descendantOf(targetNode, root)) ? = [targetNode] : [];=0A= },=0A= =0A= className: function(nodes, root, className, combinator) {=0A= if (nodes && combinator) nodes =3D this[combinator](nodes);=0A= return Selector.handlers.byClassName(nodes, root, className);=0A= },=0A= =0A= byClassName: function(nodes, root, className) {=0A= if (!nodes) nodes =3D Selector.handlers.descendant([root]);=0A= var needle =3D ' ' + className + ' ';=0A= for (var i =3D 0, results =3D [], node, nodeClassName; node =3D = nodes[i]; i++) {=0A= nodeClassName =3D node.className;=0A= if (nodeClassName.length =3D=3D 0) continue;=0A= if (nodeClassName =3D=3D className || (' ' + nodeClassName + ' = ').include(needle))=0A= results.push(node);=0A= }=0A= return results;=0A= },=0A= =0A= attrPresence: function(nodes, root, attr, combinator) {=0A= if (!nodes) nodes =3D root.getElementsByTagName("*");=0A= if (nodes && combinator) nodes =3D this[combinator](nodes);=0A= var results =3D [];=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= if (Element.hasAttribute(node, attr)) results.push(node);=0A= return results;=0A= },=0A= =0A= attr: function(nodes, root, attr, value, operator, combinator) {=0A= if (!nodes) nodes =3D root.getElementsByTagName("*");=0A= if (nodes && combinator) nodes =3D this[combinator](nodes);=0A= var handler =3D Selector.operators[operator], results =3D [];=0A= for (var i =3D 0, node; node =3D nodes[i]; i++) {=0A= var nodeValue =3D Element.readAttribute(node, attr);=0A= if (nodeValue =3D=3D=3D null) continue;=0A= if (handler(nodeValue, value)) results.push(node);=0A= }=0A= return results;=0A= },=0A= =0A= pseudo: function(nodes, name, value, root, combinator) {=0A= if (nodes && combinator) nodes =3D this[combinator](nodes);=0A= if (!nodes) nodes =3D root.getElementsByTagName("*");=0A= return Selector.pseudos[name](nodes, value, root);=0A= }=0A= },=0A= =0A= pseudos: {=0A= 'first-child': function(nodes, value, root) {=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++) {=0A= if (Selector.handlers.previousElementSibling(node)) continue;=0A= results.push(node);=0A= }=0A= return results;=0A= },=0A= 'last-child': function(nodes, value, root) {=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++) {=0A= if (Selector.handlers.nextElementSibling(node)) continue;=0A= results.push(node);=0A= }=0A= return results;=0A= },=0A= 'only-child': function(nodes, value, root) {=0A= var h =3D Selector.handlers;=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A= if (!h.previousElementSibling(node) && = !h.nextElementSibling(node))=0A= results.push(node);=0A= return results;=0A= },=0A= 'nth-child': function(nodes, formula, root) {=0A= return Selector.pseudos.nth(nodes, formula, root);=0A= },=0A= 'nth-last-child': function(nodes, formula, root) {=0A= return Selector.pseudos.nth(nodes, formula, root, true);=0A= },=0A= 'nth-of-type': function(nodes, formula, root) {=0A= return Selector.pseudos.nth(nodes, formula, root, false, true);=0A= },=0A= 'nth-last-of-type': function(nodes, formula, root) {=0A= return Selector.pseudos.nth(nodes, formula, root, true, true);=0A= },=0A= 'first-of-type': function(nodes, formula, root) {=0A= return Selector.pseudos.nth(nodes, "1", root, false, true);=0A= },=0A= 'last-of-type': function(nodes, formula, root) {=0A= return Selector.pseudos.nth(nodes, "1", root, true, true);=0A= },=0A= 'only-of-type': function(nodes, formula, root) {=0A= var p =3D Selector.pseudos;=0A= return p['last-of-type'](p['first-of-type'](nodes, formula, root), = formula, root);=0A= },=0A= =0A= // handles the an+b logic=0A= getIndices: function(a, b, total) {=0A= if (a =3D=3D 0) return b > 0 ? [b] : [];=0A= return $R(1, total).inject([], function(memo, i) {=0A= if (0 =3D=3D (i - b) % a && (i - b) / a >=3D 0) memo.push(i);=0A= return memo;=0A= });=0A= },=0A= =0A= // handles nth(-last)-child, nth(-last)-of-type, and = (first|last)-of-type=0A= nth: function(nodes, formula, root, reverse, ofType) {=0A= if (nodes.length =3D=3D 0) return [];=0A= if (formula =3D=3D 'even') formula =3D '2n+0';=0A= if (formula =3D=3D 'odd') formula =3D '2n+1';=0A= var h =3D Selector.handlers, results =3D [], indexed =3D [], m;=0A= h.mark(nodes);=0A= for (var i =3D 0, node; node =3D nodes[i]; i++) {=0A= if (!node.parentNode._countedByPrototype) {=0A= h.index(node.parentNode, reverse, ofType);=0A= indexed.push(node.parentNode);=0A= }=0A= }=0A= if (formula.match(/^\d+$/)) { // just a number=0A= formula =3D Number(formula);=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= if (node.nodeIndex =3D=3D formula) results.push(node);=0A= } else if (m =3D formula.match(/^(-?\d*)?n(([+-])(\d+))?/)) { // = an+b=0A= if (m[1] =3D=3D "-") m[1] =3D -1;=0A= var a =3D m[1] ? Number(m[1]) : 1;=0A= var b =3D m[2] ? Number(m[2]) : 0;=0A= var indices =3D Selector.pseudos.getIndices(a, b, nodes.length);=0A= for (var i =3D 0, node, l =3D indices.length; node =3D nodes[i]; = i++) {=0A= for (var j =3D 0; j < l; j++)=0A= if (node.nodeIndex =3D=3D indices[j]) results.push(node);=0A= }=0A= }=0A= h.unmark(nodes);=0A= h.unmark(indexed);=0A= return results;=0A= },=0A= =0A= 'empty': function(nodes, value, root) {=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++) {=0A= // IE treats comments as element nodes=0A= if (node.tagName =3D=3D '!' || node.firstChild) continue;=0A= results.push(node);=0A= }=0A= return results;=0A= },=0A= =0A= 'not': function(nodes, selector, root) {=0A= var h =3D Selector.handlers, selectorType, m;=0A= var exclusions =3D new Selector(selector).findElements(root);=0A= h.mark(exclusions);=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A= if (!node._countedByPrototype) results.push(node);=0A= h.unmark(exclusions);=0A= return results;=0A= },=0A= =0A= 'enabled': function(nodes, value, root) {=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A= if (!node.disabled && (!node.type || node.type !=3D=3D 'hidden'))=0A= results.push(node);=0A= return results;=0A= },=0A= =0A= 'disabled': function(nodes, value, root) {=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A= if (node.disabled) results.push(node);=0A= return results;=0A= },=0A= =0A= 'checked': function(nodes, value, root) {=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A= if (node.checked) results.push(node);=0A= return results;=0A= }=0A= },=0A= =0A= operators: {=0A= '=3D': function(nv, v) { return nv =3D=3D v; },=0A= '!=3D': function(nv, v) { return nv !=3D v; },=0A= '^=3D': function(nv, v) { return nv =3D=3D v || nv && = nv.startsWith(v); },=0A= '$=3D': function(nv, v) { return nv =3D=3D v || nv && = nv.endsWith(v); },=0A= '*=3D': function(nv, v) { return nv =3D=3D v || nv && nv.include(v); = },=0A= '$=3D': function(nv, v) { return nv.endsWith(v); },=0A= '*=3D': function(nv, v) { return nv.include(v); },=0A= '~=3D': function(nv, v) { return (' ' + nv + ' ').include(' ' + v + = ' '); },=0A= '|=3D': function(nv, v) { return ('-' + (nv || "").toUpperCase() +=0A= '-').include('-' + (v || "").toUpperCase() + '-'); }=0A= },=0A= =0A= split: function(expression) {=0A= var expressions =3D [];=0A= expression.scan(/(([\w#:.~>+()\s-]+|\*|\[.*?\])+)\s*(,|$)/, = function(m) {=0A= expressions.push(m[1].strip());=0A= });=0A= return expressions;=0A= },=0A= =0A= matchElements: function(elements, expression) {=0A= var matches =3D $$(expression), h =3D Selector.handlers;=0A= h.mark(matches);=0A= for (var i =3D 0, results =3D [], element; element =3D elements[i]; = i++)=0A= if (element._countedByPrototype) results.push(element);=0A= h.unmark(matches);=0A= return results;=0A= },=0A= =0A= findElement: function(elements, expression, index) {=0A= if (Object.isNumber(expression)) {=0A= index =3D expression; expression =3D false;=0A= }=0A= return Selector.matchElements(elements, expression || '*')[index || = 0];=0A= },=0A= =0A= findChildElements: function(element, expressions) {=0A= expressions =3D Selector.split(expressions.join(','));=0A= var results =3D [], h =3D Selector.handlers;=0A= for (var i =3D 0, l =3D expressions.length, selector; i < l; i++) {=0A= selector =3D new Selector(expressions[i].strip());=0A= h.concat(results, selector.findElements(element));=0A= }=0A= return (l > 1) ? h.unique(results) : results;=0A= }=0A= });=0A= =0A= if (Prototype.Browser.IE) {=0A= Object.extend(Selector.handlers, {=0A= // IE returns comment nodes on getElementsByTagName("*").=0A= // Filter them out.=0A= concat: function(a, b) {=0A= for (var i =3D 0, node; node =3D b[i]; i++)=0A= if (node.tagName !=3D=3D "!") a.push(node);=0A= return a;=0A= },=0A= =0A= // IE improperly serializes _countedByPrototype in (inner|outer)HTML.=0A= unmark: function(nodes) {=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= node.removeAttribute('_countedByPrototype');=0A= return nodes;=0A= }=0A= });=0A= }=0A= =0A= function $$() {=0A= return Selector.findChildElements(document, $A(arguments));=0A= }=0A= var Form =3D {=0A= reset: function(form) {=0A= $(form).reset();=0A= return form;=0A= },=0A= =0A= serializeElements: function(elements, options) {=0A= if (typeof options !=3D 'object') options =3D { hash: !!options };=0A= else if (Object.isUndefined(options.hash)) options.hash =3D true;=0A= var key, value, submitted =3D false, submit =3D options.submit;=0A= =0A= var data =3D elements.inject({ }, function(result, element) {=0A= if (!element.disabled && element.name) {=0A= key =3D element.name; value =3D $(element).getValue();=0A= if (value !=3D null && element.type !=3D 'file' && (element.type = !=3D 'submit' || (!submitted &&=0A= submit !=3D=3D false && (!submit || key =3D=3D submit) && = (submitted =3D true)))) {=0A= if (key in result) {=0A= // a key is already present; construct an array of values=0A= if (!Object.isArray(result[key])) result[key] =3D = [result[key]];=0A= result[key].push(value);=0A= }=0A= else result[key] =3D value;=0A= }=0A= }=0A= return result;=0A= });=0A= =0A= return options.hash ? data : Object.toQueryString(data);=0A= }=0A= };=0A= =0A= Form.Methods =3D {=0A= serialize: function(form, options) {=0A= return Form.serializeElements(Form.getElements(form), options);=0A= },=0A= =0A= getElements: function(form) {=0A= return $A($(form).getElementsByTagName('*')).inject([],=0A= function(elements, child) {=0A= if (Form.Element.Serializers[child.tagName.toLowerCase()])=0A= elements.push(Element.extend(child));=0A= return elements;=0A= }=0A= );=0A= },=0A= =0A= getInputs: function(form, typeName, name) {=0A= form =3D $(form);=0A= var inputs =3D form.getElementsByTagName('input');=0A= =0A= if (!typeName && !name) return $A(inputs).map(Element.extend);=0A= =0A= for (var i =3D 0, matchingInputs =3D [], length =3D inputs.length; i = < length; i++) {=0A= var input =3D inputs[i];=0A= if ((typeName && input.type !=3D typeName) || (name && input.name = !=3D name))=0A= continue;=0A= matchingInputs.push(Element.extend(input));=0A= }=0A= =0A= return matchingInputs;=0A= },=0A= =0A= disable: function(form) {=0A= form =3D $(form);=0A= Form.getElements(form).invoke('disable');=0A= return form;=0A= },=0A= =0A= enable: function(form) {=0A= form =3D $(form);=0A= Form.getElements(form).invoke('enable');=0A= return form;=0A= },=0A= =0A= findFirstElement: function(form) {=0A= var elements =3D $(form).getElements().findAll(function(element) {=0A= return 'hidden' !=3D element.type && !element.disabled;=0A= });=0A= var firstByIndex =3D elements.findAll(function(element) {=0A= return element.hasAttribute('tabIndex') && element.tabIndex >=3D 0;=0A= }).sortBy(function(element) { return element.tabIndex }).first();=0A= =0A= return firstByIndex ? firstByIndex : elements.find(function(element) = {=0A= return ['input', 'select', = 'textarea'].include(element.tagName.toLowerCase());=0A= });=0A= },=0A= =0A= focusFirstElement: function(form) {=0A= form =3D $(form);=0A= form.findFirstElement().activate();=0A= return form;=0A= },=0A= =0A= request: function(form, options) {=0A= form =3D $(form), options =3D Object.clone(options || { });=0A= =0A= var params =3D options.parameters, action =3D = form.readAttribute('action') || '';=0A= if (action.blank()) action =3D window.location.href;=0A= options.parameters =3D form.serialize(true);=0A= =0A= if (params) {=0A= if (Object.isString(params)) params =3D params.toQueryParams();=0A= Object.extend(options.parameters, params);=0A= }=0A= =0A= if (form.hasAttribute('method') && !options.method)=0A= options.method =3D form.method;=0A= =0A= return new Ajax.Request(action, options);=0A= }=0A= };=0A= =0A= /*-----------------------------------------------------------------------= ---*/=0A= =0A= Form.Element =3D {=0A= focus: function(element) {=0A= $(element).focus();=0A= return element;=0A= },=0A= =0A= select: function(element) {=0A= $(element).select();=0A= return element;=0A= }=0A= };=0A= =0A= Form.Element.Methods =3D {=0A= serialize: function(element) {=0A= element =3D $(element);=0A= if (!element.disabled && element.name) {=0A= var value =3D element.getValue();=0A= if (value !=3D undefined) {=0A= var pair =3D { };=0A= pair[element.name] =3D value;=0A= return Object.toQueryString(pair);=0A= }=0A= }=0A= return '';=0A= },=0A= =0A= getValue: function(element) {=0A= element =3D $(element);=0A= var method =3D element.tagName.toLowerCase();=0A= return Form.Element.Serializers[method](element);=0A= },=0A= =0A= setValue: function(element, value) {=0A= element =3D $(element);=0A= var method =3D element.tagName.toLowerCase();=0A= Form.Element.Serializers[method](element, value);=0A= return element;=0A= },=0A= =0A= clear: function(element) {=0A= $(element).value =3D '';=0A= return element;=0A= },=0A= =0A= present: function(element) {=0A= return $(element).value !=3D '';=0A= },=0A= =0A= activate: function(element) {=0A= element =3D $(element);=0A= try {=0A= element.focus();=0A= if (element.select && (element.tagName.toLowerCase() !=3D 'input' = ||=0A= !['button', 'reset', 'submit'].include(element.type)))=0A= element.select();=0A= } catch (e) { }=0A= return element;=0A= },=0A= =0A= disable: function(element) {=0A= element =3D $(element);=0A= element.disabled =3D true;=0A= return element;=0A= },=0A= =0A= enable: function(element) {=0A= element =3D $(element);=0A= element.disabled =3D false;=0A= return element;=0A= }=0A= };=0A= =0A= /*-----------------------------------------------------------------------= ---*/=0A= =0A= var Field =3D Form.Element;=0A= var $F =3D Form.Element.Methods.getValue;=0A= =0A= /*-----------------------------------------------------------------------= ---*/=0A= =0A= Form.Element.Serializers =3D {=0A= input: function(element, value) {=0A= switch (element.type.toLowerCase()) {=0A= case 'checkbox':=0A= case 'radio':=0A= return Form.Element.Serializers.inputSelector(element, value);=0A= default:=0A= return Form.Element.Serializers.textarea(element, value);=0A= }=0A= },=0A= =0A= inputSelector: function(element, value) {=0A= if (Object.isUndefined(value)) return element.checked ? = element.value : null;=0A= else element.checked =3D !!value;=0A= },=0A= =0A= textarea: function(element, value) {=0A= if (Object.isUndefined(value)) return element.value;=0A= else element.value =3D value;=0A= },=0A= =0A= select: function(element, value) {=0A= if (Object.isUndefined(value))=0A= return this[element.type =3D=3D 'select-one' ?=0A= 'selectOne' : 'selectMany'](element);=0A= else {=0A= var opt, currentValue, single =3D !Object.isArray(value);=0A= for (var i =3D 0, length =3D element.length; i < length; i++) {=0A= opt =3D element.options[i];=0A= currentValue =3D this.optionValue(opt);=0A= if (single) {=0A= if (currentValue =3D=3D value) {=0A= opt.selected =3D true;=0A= return;=0A= }=0A= }=0A= else opt.selected =3D value.include(currentValue);=0A= }=0A= }=0A= },=0A= =0A= selectOne: function(element) {=0A= var index =3D element.selectedIndex;=0A= return index >=3D 0 ? this.optionValue(element.options[index]) : = null;=0A= },=0A= =0A= selectMany: function(element) {=0A= var values, length =3D element.length;=0A= if (!length) return null;=0A= =0A= for (var i =3D 0, values =3D []; i < length; i++) {=0A= var opt =3D element.options[i];=0A= if (opt.selected) values.push(this.optionValue(opt));=0A= }=0A= return values;=0A= },=0A= =0A= optionValue: function(opt) {=0A= // extend element because hasAttribute may not be native=0A= return Element.extend(opt).hasAttribute('value') ? opt.value : = opt.text;=0A= }=0A= };=0A= =0A= /*-----------------------------------------------------------------------= ---*/=0A= =0A= Abstract.TimedObserver =3D Class.create(PeriodicalExecuter, {=0A= initialize: function($super, element, frequency, callback) {=0A= $super(callback, frequency);=0A= this.element =3D $(element);=0A= this.lastValue =3D this.getValue();=0A= },=0A= =0A= execute: function() {=0A= var value =3D this.getValue();=0A= if (Object.isString(this.lastValue) && Object.isString(value) ?=0A= this.lastValue !=3D value : String(this.lastValue) !=3D = String(value)) {=0A= this.callback(this.element, value);=0A= this.lastValue =3D value;=0A= }=0A= }=0A= });=0A= =0A= Form.Element.Observer =3D Class.create(Abstract.TimedObserver, {=0A= getValue: function() {=0A= return Form.Element.getValue(this.element);=0A= }=0A= });=0A= =0A= Form.Observer =3D Class.create(Abstract.TimedObserver, {=0A= getValue: function() {=0A= return Form.serialize(this.element);=0A= }=0A= });=0A= =0A= /*-----------------------------------------------------------------------= ---*/=0A= =0A= Abstract.EventObserver =3D Class.create({=0A= initialize: function(element, callback) {=0A= this.element =3D $(element);=0A= this.callback =3D callback;=0A= =0A= this.lastValue =3D this.getValue();=0A= if (this.element.tagName.toLowerCase() =3D=3D 'form')=0A= this.registerFormCallbacks();=0A= else=0A= this.registerCallback(this.element);=0A= },=0A= =0A= onElementEvent: function() {=0A= var value =3D this.getValue();=0A= if (this.lastValue !=3D value) {=0A= this.callback(this.element, value);=0A= this.lastValue =3D value;=0A= }=0A= },=0A= =0A= registerFormCallbacks: function() {=0A= Form.getElements(this.element).each(this.registerCallback, this);=0A= },=0A= =0A= registerCallback: function(element) {=0A= if (element.type) {=0A= switch (element.type.toLowerCase()) {=0A= case 'checkbox':=0A= case 'radio':=0A= Event.observe(element, 'click', = this.onElementEvent.bind(this));=0A= break;=0A= default:=0A= Event.observe(element, 'change', = this.onElementEvent.bind(this));=0A= break;=0A= }=0A= }=0A= }=0A= });=0A= =0A= Form.Element.EventObserver =3D Class.create(Abstract.EventObserver, {=0A= getValue: function() {=0A= return Form.Element.getValue(this.element);=0A= }=0A= });=0A= =0A= Form.EventObserver =3D Class.create(Abstract.EventObserver, {=0A= getValue: function() {=0A= return Form.serialize(this.element);=0A= }=0A= });=0A= if (!window.Event) var Event =3D { };=0A= =0A= Object.extend(Event, {=0A= KEY_BACKSPACE: 8,=0A= KEY_TAB: 9,=0A= KEY_RETURN: 13,=0A= KEY_ESC: 27,=0A= KEY_LEFT: 37,=0A= KEY_UP: 38,=0A= KEY_RIGHT: 39,=0A= KEY_DOWN: 40,=0A= KEY_DELETE: 46,=0A= KEY_HOME: 36,=0A= KEY_END: 35,=0A= KEY_PAGEUP: 33,=0A= KEY_PAGEDOWN: 34,=0A= KEY_INSERT: 45,=0A= =0A= cache: { },=0A= =0A= relatedTarget: function(event) {=0A= var element;=0A= switch(event.type) {=0A= case 'mouseover': element =3D event.fromElement; break;=0A= case 'mouseout': element =3D event.toElement; break;=0A= default: return null;=0A= }=0A= return Element.extend(element);=0A= }=0A= });=0A= =0A= Event.Methods =3D (function() {=0A= var isButton;=0A= =0A= if (Prototype.Browser.IE) {=0A= var buttonMap =3D { 0: 1, 1: 4, 2: 2 };=0A= isButton =3D function(event, code) {=0A= return event.button =3D=3D buttonMap[code];=0A= };=0A= =0A= } else if (Prototype.Browser.WebKit) {=0A= isButton =3D function(event, code) {=0A= switch (code) {=0A= case 0: return event.which =3D=3D 1 && !event.metaKey;=0A= case 1: return event.which =3D=3D 1 && event.metaKey;=0A= default: return false;=0A= }=0A= };=0A= =0A= } else {=0A= isButton =3D function(event, code) {=0A= return event.which ? (event.which =3D=3D=3D code + 1) : = (event.button =3D=3D=3D code);=0A= };=0A= }=0A= =0A= return {=0A= isLeftClick: function(event) { return isButton(event, 0) },=0A= isMiddleClick: function(event) { return isButton(event, 1) },=0A= isRightClick: function(event) { return isButton(event, 2) },=0A= =0A= element: function(event) {=0A= event =3D Event.extend(event);=0A= =0A= var node =3D event.target,=0A= type =3D event.type,=0A= currentTarget =3D event.currentTarget;=0A= =0A= if (currentTarget && currentTarget.tagName) {=0A= // Firefox screws up the "click" event when moving between radio = buttons=0A= // via arrow keys. It also screws up the "load" and "error" = events on images,=0A= // reporting the document as the target instead of the original = image.=0A= if (type =3D=3D=3D 'load' || type =3D=3D=3D 'error' ||=0A= (type =3D=3D=3D 'click' && currentTarget.tagName.toLowerCase() = =3D=3D=3D 'input'=0A= && currentTarget.type =3D=3D=3D 'radio'))=0A= node =3D currentTarget;=0A= }=0A= if (node.nodeType =3D=3D Node.TEXT_NODE) node =3D node.parentNode;=0A= return Element.extend(node);=0A= },=0A= =0A= findElement: function(event, expression) {=0A= var element =3D Event.element(event);=0A= if (!expression) return element;=0A= var elements =3D [element].concat(element.ancestors());=0A= return Selector.findElement(elements, expression, 0);=0A= },=0A= =0A= pointer: function(event) {=0A= var docElement =3D document.documentElement,=0A= body =3D document.body || { scrollLeft: 0, scrollTop: 0 };=0A= return {=0A= x: event.pageX || (event.clientX +=0A= (docElement.scrollLeft || body.scrollLeft) -=0A= (docElement.clientLeft || 0)),=0A= y: event.pageY || (event.clientY +=0A= (docElement.scrollTop || body.scrollTop) -=0A= (docElement.clientTop || 0))=0A= };=0A= },=0A= =0A= pointerX: function(event) { return Event.pointer(event).x },=0A= pointerY: function(event) { return Event.pointer(event).y },=0A= =0A= stop: function(event) {=0A= Event.extend(event);=0A= event.preventDefault();=0A= event.stopPropagation();=0A= event.stopped =3D true;=0A= }=0A= };=0A= })();=0A= =0A= Event.extend =3D (function() {=0A= var methods =3D Object.keys(Event.Methods).inject({ }, function(m, = name) {=0A= m[name] =3D Event.Methods[name].methodize();=0A= return m;=0A= });=0A= =0A= if (Prototype.Browser.IE) {=0A= Object.extend(methods, {=0A= stopPropagation: function() { this.cancelBubble =3D true },=0A= preventDefault: function() { this.returnValue =3D false },=0A= inspect: function() { return "[object Event]" }=0A= });=0A= =0A= return function(event) {=0A= if (!event) return false;=0A= if (event._extendedByPrototype) return event;=0A= =0A= event._extendedByPrototype =3D Prototype.emptyFunction;=0A= var pointer =3D Event.pointer(event);=0A= Object.extend(event, {=0A= target: event.srcElement,=0A= relatedTarget: Event.relatedTarget(event),=0A= pageX: pointer.x,=0A= pageY: pointer.y=0A= });=0A= return Object.extend(event, methods);=0A= };=0A= =0A= } else {=0A= Event.prototype =3D Event.prototype || = document.createEvent("HTMLEvents")['__proto__'];=0A= Object.extend(Event.prototype, methods);=0A= return Prototype.K;=0A= }=0A= })();=0A= =0A= Object.extend(Event, (function() {=0A= var cache =3D Event.cache;=0A= =0A= function getEventID(element) {=0A= if (element._prototypeEventID) return element._prototypeEventID[0];=0A= arguments.callee.id =3D arguments.callee.id || 1;=0A= return element._prototypeEventID =3D [++arguments.callee.id];=0A= }=0A= =0A= function getDOMEventName(eventName) {=0A= if (eventName && eventName.include(':')) return "dataavailable";=0A= return eventName;=0A= }=0A= =0A= function getCacheForID(id) {=0A= return cache[id] =3D cache[id] || { };=0A= }=0A= =0A= function getWrappersForEventName(id, eventName) {=0A= var c =3D getCacheForID(id);=0A= return c[eventName] =3D c[eventName] || [];=0A= }=0A= =0A= function createWrapper(element, eventName, handler) {=0A= var id =3D getEventID(element);=0A= var c =3D getWrappersForEventName(id, eventName);=0A= if (c.pluck("handler").include(handler)) return false;=0A= =0A= var wrapper =3D function(event) {=0A= if (!Event || !Event.extend ||=0A= (event.eventName && event.eventName !=3D eventName))=0A= return false;=0A= =0A= Event.extend(event);=0A= handler.call(element, event);=0A= };=0A= =0A= wrapper.handler =3D handler;=0A= c.push(wrapper);=0A= return wrapper;=0A= }=0A= =0A= function findWrapper(id, eventName, handler) {=0A= var c =3D getWrappersForEventName(id, eventName);=0A= return c.find(function(wrapper) { return wrapper.handler =3D=3D = handler });=0A= }=0A= =0A= function destroyWrapper(id, eventName, handler) {=0A= var c =3D getCacheForID(id);=0A= if (!c[eventName]) return false;=0A= c[eventName] =3D c[eventName].without(findWrapper(id, eventName, = handler));=0A= }=0A= =0A= function destroyCache() {=0A= for (var id in cache)=0A= for (var eventName in cache[id])=0A= cache[id][eventName] =3D null;=0A= }=0A= =0A= =0A= // Internet Explorer needs to remove event handlers on page unload=0A= // in order to avoid memory leaks.=0A= if (window.attachEvent) {=0A= window.attachEvent("onunload", destroyCache);=0A= }=0A= =0A= // Safari has a dummy event handler on page unload so that it won't=0A= // use its bfcache. Safari <=3D 3.1 has an issue with restoring the = "document"=0A= // object when page is returned to via the back button using its = bfcache.=0A= if (Prototype.Browser.WebKit) {=0A= window.addEventListener('unload', Prototype.emptyFunction, false);=0A= }=0A= =0A= return {=0A= observe: function(element, eventName, handler) {=0A= element =3D $(element);=0A= var name =3D getDOMEventName(eventName);=0A= =0A= var wrapper =3D createWrapper(element, eventName, handler);=0A= if (!wrapper) return element;=0A= =0A= if (element.addEventListener) {=0A= element.addEventListener(name, wrapper, false);=0A= } else {=0A= element.attachEvent("on" + name, wrapper);=0A= }=0A= =0A= return element;=0A= },=0A= =0A= stopObserving: function(element, eventName, handler) {=0A= element =3D $(element);=0A= var id =3D getEventID(element), name =3D = getDOMEventName(eventName);=0A= =0A= if (!handler && eventName) {=0A= getWrappersForEventName(id, eventName).each(function(wrapper) {=0A= element.stopObserving(eventName, wrapper.handler);=0A= });=0A= return element;=0A= =0A= } else if (!eventName) {=0A= Object.keys(getCacheForID(id)).each(function(eventName) {=0A= element.stopObserving(eventName);=0A= });=0A= return element;=0A= }=0A= =0A= var wrapper =3D findWrapper(id, eventName, handler);=0A= if (!wrapper) return element;=0A= =0A= if (element.removeEventListener) {=0A= element.removeEventListener(name, wrapper, false);=0A= } else {=0A= element.detachEvent("on" + name, wrapper);=0A= }=0A= =0A= destroyWrapper(id, eventName, handler);=0A= =0A= return element;=0A= },=0A= =0A= fire: function(element, eventName, memo) {=0A= element =3D $(element);=0A= if (element =3D=3D document && document.createEvent && = !element.dispatchEvent)=0A= element =3D document.documentElement;=0A= =0A= var event;=0A= if (document.createEvent) {=0A= event =3D document.createEvent("HTMLEvents");=0A= event.initEvent("dataavailable", true, true);=0A= } else {=0A= event =3D document.createEventObject();=0A= event.eventType =3D "ondataavailable";=0A= }=0A= =0A= event.eventName =3D eventName;=0A= event.memo =3D memo || { };=0A= =0A= if (document.createEvent) {=0A= element.dispatchEvent(event);=0A= } else {=0A= element.fireEvent(event.eventType, event);=0A= }=0A= =0A= return Event.extend(event);=0A= }=0A= };=0A= })());=0A= =0A= Object.extend(Event, Event.Methods);=0A= =0A= Element.addMethods({=0A= fire: Event.fire,=0A= observe: Event.observe,=0A= stopObserving: Event.stopObserving=0A= });=0A= =0A= Object.extend(document, {=0A= fire: Element.Methods.fire.methodize(),=0A= observe: Element.Methods.observe.methodize(),=0A= stopObserving: Element.Methods.stopObserving.methodize(),=0A= loaded: false=0A= });=0A= =0A= (function() {=0A= /* Support for the DOMContentLoaded event is based on work by Dan Webb,=0A= Matthias Miller, Dean Edwards and John Resig. */=0A= =0A= var timer;=0A= =0A= function fireContentLoadedEvent() {=0A= if (document.loaded) return;=0A= if (timer) window.clearInterval(timer);=0A= document.fire("dom:loaded");=0A= document.loaded =3D true;=0A= }=0A= =0A= if (document.addEventListener) {=0A= if (Prototype.Browser.WebKit) {=0A= timer =3D window.setInterval(function() {=0A= if (/loaded|complete/.test(document.readyState))=0A= fireContentLoadedEvent();=0A= }, 0);=0A= =0A= Event.observe(window, "load", fireContentLoadedEvent);=0A= =0A= } else {=0A= document.addEventListener("DOMContentLoaded",=0A= fireContentLoadedEvent, false);=0A= }=0A= =0A= } else {=0A= document.write("This is a p

=0A= * @before $.metadata.setType("elem", "script")=0A= * @after $("#one").metadata().item_id =3D=3D 1; = $("#one").metadata().item_label =3D=3D "Label"=0A= * @desc Reads metadata from a nested script element=0A= * =0A= * @param String type The encoding type=0A= * @param String name The name of the attribute to be used to get = metadata (optional)=0A= * @cat Plugins/Metadata=0A= * @descr Sets the type of encoding to be used when loading metadata for = the first time=0A= * @type undefined=0A= * @see metadata()=0A= */=0A= =0A= (function($) {=0A= =0A= $.extend({=0A= metadata : {=0A= defaults : {=0A= type: 'class',=0A= name: 'metadata',=0A= cre: /({.*})/,=0A= single: 'metadata'=0A= },=0A= setType: function( type, name ){=0A= this.defaults.type =3D type;=0A= this.defaults.name =3D name;=0A= },=0A= get: function( elem, opts ){=0A= var settings =3D $.extend({},this.defaults,opts);=0A= // check for empty string in single property=0A= if ( !settings.single.length ) settings.single =3D 'metadata';=0A= =0A= var data =3D $.data(elem, settings.single);=0A= // returned cached data if it already exists=0A= if ( data ) return data;=0A= =0A= data =3D "{}";=0A= =0A= if ( settings.type =3D=3D "class" ) {=0A= var m =3D settings.cre.exec( elem.className );=0A= if ( m )=0A= data =3D m[1];=0A= } else if ( settings.type =3D=3D "elem" ) {=0A= if( !elem.getElementsByTagName ) return;=0A= var e =3D elem.getElementsByTagName(settings.name);=0A= if ( e.length )=0A= data =3D $.trim(e[0].innerHTML);=0A= } else if ( elem.getAttribute !=3D undefined ) {=0A= var attr =3D elem.getAttribute( settings.name );=0A= if ( attr )=0A= data =3D attr;=0A= }=0A= =0A= if ( data.indexOf( '{' ) <0 )=0A= data =3D "{" + data + "}";=0A= =0A= data =3D eval("(" + data + ")");=0A= =0A= $.data( elem, settings.single, data );=0A= return data;=0A= }=0A= }=0A= });=0A= =0A= /**=0A= * Returns the metadata object for the first member of the jQuery object.=0A= *=0A= * @name metadata=0A= * @descr Returns element's metadata object=0A= * @param Object opts An object contianing settings to override the = defaults=0A= * @type jQuery=0A= * @cat Plugins/Metadata=0A= */=0A= $.fn.metadata =3D function( opts ){=0A= return $.metadata.get( this[0], opts );=0A= };=0A= =0A= })(jQuery); ------=_NextPart_000_00D3_01CC0B12.32205B80 Content-Type: application/octet-stream Content-Transfer-Encoding: quoted-printable Content-Location: http://www.heidolph-instruments.co.uk/typo3conf/ext/jq_fancybox/fancybox/js/jquery.fancybox-1.0.0.js /* * FancyBox - simple jQuery plugin for fancy image zooming * Examples and documentation at: http://fancy.klade.lv/ * Version: 1.0.0 (29/04/2008) * Copyright (c) 2008 Janis Skarnelis * Licensed under the MIT License: = http://www.opensource.org/licenses/mit-license.php * Requires: jQuery v1.2.1 or later */ (function($) { var opts =3D {},=20 imgPreloader =3D new Image, imgTypes =3D ['png', 'jpg', 'jpeg', = 'gif'],=20 loadingTimer, loadingFrame =3D 1; $.fn.fancybox =3D function(settings) { opts.settings =3D $.extend({}, $.fn.fancybox.defaults, settings); $.fn.fancybox.init(); return this.each(function() { var $this =3D $(this); var o =3D $.metadata ? $.extend({}, opts.settings, $this.metadata()) = : opts.settings; $this.unbind('click').click(function() { $.fn.fancybox.start(this, o); return false; }); }); }; $.fn.fancybox.start =3D function(el, o) { if (opts.animating) return false; if (o.overlayShow) { $("#fancy_wrap").prepend('
'); $("#fancy_overlay").css({'width': $(window).width(), 'height': = $(document).height(), 'opacity': o.overlayOpacity}); if ($.browser.msie) { $("#fancy_wrap").prepend(''); $("#fancy_bigIframe").css({'width': $(window).width(), 'height': = $(document).height(), 'opacity': 0}); } $("#fancy_overlay").click($.fn.fancybox.close); } opts.itemArray =3D []; opts.itemNum =3D 0; if (jQuery.isFunction(o.itemLoadCallback)) { o.itemLoadCallback.apply(this, [opts]); var c =3D $(el).children("img:first").length ? = $(el).children("img:first") : $(el); var tmp =3D {'width': c.width(), 'height': c.height(), 'pos': = $.fn.fancybox.getPosition(c)} for (var i =3D 0; i < opts.itemArray.length; i++) { opts.itemArray[i].o =3D $.extend({}, o, opts.itemArray[i].o); =09 if (o.zoomSpeedIn > 0 || o.zoomSpeedOut > 0) { opts.itemArray[i].orig =3D tmp; } } } else { if (!el.rel || el.rel =3D=3D '') { var item =3D {url: el.href, title: el.title, o: o}; if (o.zoomSpeedIn > 0 || o.zoomSpeedOut > 0) { var c =3D $(el).children("img:first").length ? = $(el).children("img:first") : $(el); item.orig =3D {'width': c.width(), 'height': c.height(), 'pos': = $.fn.fancybox.getPosition(c)} } opts.itemArray.push(item); } else { var arr =3D $("a[@rel=3D" + el.rel + "]").get(); for (var i =3D 0; i < arr.length; i++) { var tmp =3D $.metadata ? $.extend({}, o, $(arr[i]).metadata()) : = o; var item =3D {url: arr[i].href, title: arr[i].title, o: tmp}; if (o.zoomSpeedIn > 0 || o.zoomSpeedOut > 0) { var c =3D $(arr[i]).children("img:first").length ? = $(arr[i]).children("img:first") : $(el); item.orig =3D {'width': c.width(), 'height': c.height(), 'pos': = $.fn.fancybox.getPosition(c)} } if (arr[i].href =3D=3D el.href) opts.itemNum =3D i; opts.itemArray.push(item); } } } $.fn.fancybox.changeItem(opts.itemNum); }; $.fn.fancybox.changeItem =3D function(n) { $.fn.fancybox.showLoading(); opts.itemNum =3D n; $("#fancy_nav").empty(); $("#fancy_outer").stop(); $("#fancy_title").hide(); $(document).unbind("keydown"); imgRegExp =3D imgTypes.join('|'); imgRegExp =3D new RegExp('\.' + imgRegExp + '$', 'i'); var url =3D opts.itemArray[n].url; if (url.match(/#/)) { var target =3D window.location.href.split('#')[0]; target =3D = url.replace(target,''); $.fn.fancybox.showItem('
' + = $(target).html() + '
'); $("#fancy_loading").hide(); } else if (url.match(imgRegExp)) { $(imgPreloader).unbind('load').bind('load', function() { $("#fancy_loading").hide(); opts.itemArray[n].o.frameWidth =3D imgPreloader.width; opts.itemArray[n].o.frameHeight =3D imgPreloader.height; $.fn.fancybox.showItem(''); }).attr('src', url + '?rand=3D' + Math.floor(Math.random() * = 999999999) ); } else { $.fn.fancybox.showItem(''); } }; $.fn.fancybox.showIframe =3D function() { $("#fancy_loading").hide(); $("#fancy_frame").show(); }; $.fn.fancybox.showItem =3D function(val) { $.fn.fancybox.preloadNeighborImages(); var viewportPos =3D $.fn.fancybox.getViewport(); var itemSize =3D $.fn.fancybox.getMaxSize(viewportPos[0] - 50, = viewportPos[1] - 100, opts.itemArray[opts.itemNum].o.frameWidth, = opts.itemArray[opts.itemNum].o.frameHeight); var itemLeft =3D viewportPos[2] + Math.round((viewportPos[0] - = itemSize[0]) / 2) - 20; var itemTop =3D viewportPos[3] + Math.round((viewportPos[1] - = itemSize[1]) / 2) - 40; var itemOpts =3D { 'left': itemLeft,=20 'top': itemTop,=20 'width': itemSize[0] + 'px',=20 'height': itemSize[1] + 'px'=09 } if (opts.active) { $('#fancy_content').fadeOut("normal", function() { $("#fancy_content").empty(); =09 $("#fancy_outer").animate(itemOpts, "normal", function() { $("#fancy_content").append($(val)).fadeIn("normal"); $.fn.fancybox.updateDetails(); }); }); } else { opts.active =3D true; $("#fancy_content").empty(); if ($("#fancy_content").is(":animated")) { console.info('animated!'); } if (opts.itemArray[opts.itemNum].o.zoomSpeedIn > 0) { opts.animating =3D true; itemOpts.opacity =3D "show"; $("#fancy_outer").css({ 'top': opts.itemArray[opts.itemNum].orig.pos.top - 18, 'left': opts.itemArray[opts.itemNum].orig.pos.left - 18, 'height': opts.itemArray[opts.itemNum].orig.height, 'width': opts.itemArray[opts.itemNum].orig.width }); $("#fancy_content").append($(val)).show(); $("#fancy_outer").animate(itemOpts, = opts.itemArray[opts.itemNum].o.zoomSpeedIn, function() { opts.animating =3D false; $.fn.fancybox.updateDetails(); }); } else { $("#fancy_content").append($(val)).show(); $("#fancy_outer").css(itemOpts).show(); $.fn.fancybox.updateDetails(); } } }; $.fn.fancybox.updateDetails =3D function() { $("#fancy_bg,#fancy_close").show(); if (opts.itemArray[opts.itemNum].title !=3D=3D undefined && = opts.itemArray[opts.itemNum].title !=3D=3D '') { $('#fancy_title div').html(opts.itemArray[opts.itemNum].title); $('#fancy_title').show(); } if (opts.itemArray[opts.itemNum].o.hideOnContentClick) { $("#fancy_content").click($.fn.fancybox.close); } else { $("#fancy_content").unbind('click'); } if (opts.itemNum !=3D 0) { $("#fancy_nav").append(''); $('#fancy_left').click(function() { $.fn.fancybox.changeItem(opts.itemNum - 1); return false; }); } if (opts.itemNum !=3D (opts.itemArray.length - 1)) { $("#fancy_nav").append(''); =09 $('#fancy_right').click(function(){ $.fn.fancybox.changeItem(opts.itemNum + 1); return false; }); } $(document).keydown(function(event) { if (event.keyCode =3D=3D 27) { $.fn.fancybox.close(); } else if(event.keyCode =3D=3D 37 && opts.itemNum !=3D 0) { $.fn.fancybox.changeItem(opts.itemNum - 1); } else if(event.keyCode =3D=3D 39 && opts.itemNum !=3D = (opts.itemArray.length - 1)) { $.fn.fancybox.changeItem(opts.itemNum + 1); } }); }; $.fn.fancybox.preloadNeighborImages =3D function() { if ((opts.itemArray.length - 1) > opts.itemNum) { preloadNextImage =3D new Image(); preloadNextImage.src =3D opts.itemArray[opts.itemNum + 1].url; } if (opts.itemNum > 0) { preloadPrevImage =3D new Image(); preloadPrevImage.src =3D opts.itemArray[opts.itemNum - 1].url; } }; $.fn.fancybox.close =3D function() { if (opts.animating) return false; $(imgPreloader).unbind('load'); $(document).unbind("keydown"); $("#fancy_loading,#fancy_title,#fancy_close,#fancy_bg").hide(); $("#fancy_nav").empty(); opts.active =3D false; if (opts.itemArray[opts.itemNum].o.zoomSpeedOut > 0) { var itemOpts =3D { 'top': opts.itemArray[opts.itemNum].orig.pos.top - 18, 'left': opts.itemArray[opts.itemNum].orig.pos.left - 18, 'height': opts.itemArray[opts.itemNum].orig.height, 'width': opts.itemArray[opts.itemNum].orig.width, 'opacity': 'hide' }; opts.animating =3D true; $("#fancy_outer").animate(itemOpts, = opts.itemArray[opts.itemNum].o.zoomSpeedOut, function() { $("#fancy_content").hide().empty(); $("#fancy_overlay,#fancy_bigIframe").remove(); opts.animating =3D false; }); } else { $("#fancy_outer").hide(); $("#fancy_content").hide().empty(); $("#fancy_overlay,#fancy_bigIframe").fadeOut("fast").remove(); } }; $.fn.fancybox.showLoading =3D function() { clearInterval(loadingTimer); var pos =3D $.fn.fancybox.getViewport(); $("#fancy_loading").css({'left': ((pos[0] - 40) / 2 + pos[2]), 'top': = ((pos[1] - 40) / 2 + pos[3])}).show(); $("#fancy_loading").bind('click', $.fn.fancybox.close); =09 loadingTimer =3D setInterval($.fn.fancybox.animateLoading, 66); }; $.fn.fancybox.animateLoading =3D function(el, o) { if (!$("#fancy_loading").is(':visible')){ clearInterval(loadingTimer); return; } $("#fancy_loading > div").css('top', (loadingFrame * -40) + 'px'); loadingFrame =3D (loadingFrame + 1) % 12; }; $.fn.fancybox.init =3D function() { if (!$('#fancy_wrap').length) { $('
').appendTo("body"); $('
').prependTo("#fancy_inner"); =09 $('
').appendTo('#fancy_title'); } if ($.browser.msie) { $("#fancy_inner").prepend(''); } if (jQuery.fn.pngFix) $(document).pngFix(); $("#fancy_close").click($.fn.fancybox.close); }; $.fn.fancybox.getPosition =3D function(el) { var pos =3D el.offset(); pos.top +=3D $.fn.fancybox.num(el, 'paddingTop'); pos.top +=3D $.fn.fancybox.num(el, 'borderTopWidth'); pos.left +=3D $.fn.fancybox.num(el, 'paddingLeft'); pos.left +=3D $.fn.fancybox.num(el, 'borderLeftWidth'); return pos; }; $.fn.fancybox.num =3D function (el, prop) { return parseInt($.curCSS(el.jquery?el[0]:el,prop,true))||0; }; $.fn.fancybox.getPageScroll =3D function() { var xScroll, yScroll; if (self.pageYOffset) { yScroll =3D self.pageYOffset; xScroll =3D self.pageXOffset; } else if (document.documentElement && = document.documentElement.scrollTop) { yScroll =3D document.documentElement.scrollTop; xScroll =3D document.documentElement.scrollLeft; } else if (document.body) { yScroll =3D document.body.scrollTop; xScroll =3D document.body.scrollLeft;=09 } return [xScroll, yScroll];=20 }; $.fn.fancybox.getViewport =3D function() { var scroll =3D $.fn.fancybox.getPageScroll(); return [$(window).width(), $(window).height(), scroll[0], scroll[1]]; }; $.fn.fancybox.getMaxSize =3D function(maxWidth, maxHeight, imageWidth, = imageHeight) { var r =3D Math.min(Math.min(maxWidth, imageWidth) / imageWidth, = Math.min(maxHeight, imageHeight) / imageHeight); return [Math.round(r * imageWidth), Math.round(r * imageHeight)]; }; $.fn.fancybox.defaults =3D { hideOnContentClick: false, zoomSpeedIn: 500, zoomSpeedOut: 500, frameWidth: 600, frameHeight: 400, overlayShow: false, overlayOpacity: 0.4, itemLoadCallback: null }; })(jQuery); ------=_NextPart_000_00D3_01CC0B12.32205B80 Content-Type: application/octet-stream Content-Transfer-Encoding: quoted-printable Content-Location: http://www.heidolph-instruments.co.uk/fileadmin/flash/neue_produktkataloge/AC_RunActiveContent.js //v1.7 // Flash Player Version Detection // Detect Client Browser type // Copyright 2005-2007 Adobe Systems Incorporated. All rights reserved. var isIE =3D (navigator.appVersion.indexOf("MSIE") !=3D -1) ? true : = false; var isWin =3D (navigator.appVersion.toLowerCase().indexOf("win") !=3D = -1) ? true : false; var isOpera =3D (navigator.userAgent.indexOf("Opera") !=3D -1) ? true : = false; function ControlVersion() { var version; var axo; var e; // NOTE : new ActiveXObject(strFoo) throws an exception if strFoo isn't = in the registry try { // version will be set for 7.X or greater players axo =3D new ActiveXObject("ShockwaveFlash.ShockwaveFlash.7"); version =3D axo.GetVariable("$version"); } catch (e) { } if (!version) { try { // version will be set for 6.X players only axo =3D new ActiveXObject("ShockwaveFlash.ShockwaveFlash.6"); =09 // installed player is some revision of 6.0 // GetVariable("$version") crashes for versions 6.0.22 through = 6.0.29, // so we have to be careful.=20 =09 // default to the first public version version =3D "WIN 6,0,21,0"; // throws if AllowScripAccess does not exist (introduced in 6.0r47) =09 axo.AllowScriptAccess =3D "always"; // safe to call for 6.0r47 or greater version =3D axo.GetVariable("$version"); } catch (e) { } } if (!version) { try { // version will be set for 4.X or 5.X player axo =3D new ActiveXObject("ShockwaveFlash.ShockwaveFlash.3"); version =3D axo.GetVariable("$version"); } catch (e) { } } if (!version) { try { // version will be set for 3.X player axo =3D new ActiveXObject("ShockwaveFlash.ShockwaveFlash.3"); version =3D "WIN 3,0,18,0"; } catch (e) { } } if (!version) { try { // version will be set for 2.X player axo =3D new ActiveXObject("ShockwaveFlash.ShockwaveFlash"); version =3D "WIN 2,0,0,11"; } catch (e) { version =3D -1; } } =09 return version; } // JavaScript helper required to detect Flash Player PlugIn version = information function GetSwfVer(){ // NS/Opera version >=3D 3 check for Flash plugin in plugin array var flashVer =3D -1; =09 if (navigator.plugins !=3D null && navigator.plugins.length > 0) { if (navigator.plugins["Shockwave Flash 2.0"] || = navigator.plugins["Shockwave Flash"]) { var swVer2 =3D navigator.plugins["Shockwave Flash 2.0"] ? " 2.0" : = ""; var flashDescription =3D navigator.plugins["Shockwave Flash" + = swVer2].description; var descArray =3D flashDescription.split(" "); var tempArrayMajor =3D descArray[2].split("."); =09 var versionMajor =3D tempArrayMajor[0]; var versionMinor =3D tempArrayMajor[1]; var versionRevision =3D descArray[3]; if (versionRevision =3D=3D "") { versionRevision =3D descArray[4]; } if (versionRevision[0] =3D=3D "d") { versionRevision =3D versionRevision.substring(1); } else if (versionRevision[0] =3D=3D "r") { versionRevision =3D versionRevision.substring(1); if (versionRevision.indexOf("d") > 0) { versionRevision =3D versionRevision.substring(0, = versionRevision.indexOf("d")); } } var flashVer =3D versionMajor + "." + versionMinor + "." + = versionRevision; } } // MSN/WebTV 2.6 supports Flash 4 else if (navigator.userAgent.toLowerCase().indexOf("webtv/2.6") !=3D = -1) flashVer =3D 4; // WebTV 2.5 supports Flash 3 else if (navigator.userAgent.toLowerCase().indexOf("webtv/2.5") !=3D = -1) flashVer =3D 3; // older WebTV supports Flash 2 else if (navigator.userAgent.toLowerCase().indexOf("webtv") !=3D -1) = flashVer =3D 2; else if ( isIE && isWin && !isOpera ) { flashVer =3D ControlVersion(); }=09 return flashVer; } // When called with reqMajorVer, reqMinorVer, reqRevision returns true = if that version or greater is available function DetectFlashVer(reqMajorVer, reqMinorVer, reqRevision) { versionStr =3D GetSwfVer(); if (versionStr =3D=3D -1 ) { return false; } else if (versionStr !=3D 0) { if(isIE && isWin && !isOpera) { // Given "WIN 2,0,0,11" tempArray =3D versionStr.split(" "); // ["WIN", "2,0,0,11"] tempString =3D tempArray[1]; // "2,0,0,11" versionArray =3D tempString.split(","); // ['2', '0', '0', '11'] } else { versionArray =3D versionStr.split("."); } var versionMajor =3D versionArray[0]; var versionMinor =3D versionArray[1]; var versionRevision =3D versionArray[2]; // is the major.revision >=3D requested major.revision AND the = minor version >=3D requested minor if (versionMajor > parseFloat(reqMajorVer)) { return true; } else if (versionMajor =3D=3D parseFloat(reqMajorVer)) { if (versionMinor > parseFloat(reqMinorVer)) return true; else if (versionMinor =3D=3D parseFloat(reqMinorVer)) { if (versionRevision >=3D parseFloat(reqRevision)) return true; } } return false; } } function AC_AddExtension(src, ext) { if (src.indexOf('?') !=3D -1) return src.replace(/\?/, ext+'?');=20 else return src + ext; } function AC_Generateobj(objAttrs, params, embedAttrs)=20 {=20 var str =3D ''; if (isIE && isWin && !isOpera) { str +=3D ''; for (var i in params) { str +=3D ' = '; } str +=3D ''; } else { str +=3D ' '; } document.write(str); } function AC_FL_RunContent(){ var ret =3D=20 AC_GetArgs ( arguments, ".swf", "movie", = "clsid:d27cdb6e-ae6d-11cf-96b8-444553540000" , "application/x-shockwave-flash" ); AC_Generateobj(ret.objAttrs, ret.params, ret.embedAttrs); } function AC_SW_RunContent(){ var ret =3D=20 AC_GetArgs ( arguments, ".dcr", "src", = "clsid:166B1BCA-3F9C-11CF-8075-444553540000" , null ); AC_Generateobj(ret.objAttrs, ret.params, ret.embedAttrs); } function AC_GetArgs(args, ext, srcParamName, classid, mimeType){ var ret =3D new Object(); ret.embedAttrs =3D new Object(); ret.params =3D new Object(); ret.objAttrs =3D new Object(); for (var i=3D0; i < args.length; i=3Di+2){ var currArg =3D args[i].toLowerCase(); =20 switch (currArg){=09 case "classid": break; case "pluginspage": ret.embedAttrs[args[i]] =3D args[i+1]; break; case "src": case "movie":=09 args[i+1] =3D AC_AddExtension(args[i+1], ext); ret.embedAttrs["src"] =3D args[i+1]; ret.params[srcParamName] =3D args[i+1]; break; case "onafterupdate": case "onbeforeupdate": case "onblur": case "oncellchange": case "onclick": case "ondblclick": case "ondrag": case "ondragend": case "ondragenter": case "ondragleave": case "ondragover": case "ondrop": case "onfinish": case "onfocus": case "onhelp": case "onmousedown": case "onmouseup": case "onmouseover": case "onmousemove": case "onmouseout": case "onkeypress": case "onkeydown": case "onkeyup": case "onload": case "onlosecapture": case "onpropertychange": case "onreadystatechange": case "onrowsdelete": case "onrowenter": case "onrowexit": case "onrowsinserted": case "onstart": case "onscroll": case "onbeforeeditfocus": case "onactivate": case "onbeforedeactivate": case "ondeactivate": case "type": case "codebase": case "id": ret.objAttrs[args[i]] =3D args[i+1]; break; case "width": case "height": case "align": case "vspace":=20 case "hspace": case "class": case "title": case "accesskey": case "name": case "tabindex": ret.embedAttrs[args[i]] =3D ret.objAttrs[args[i]] =3D args[i+1]; break; default: ret.embedAttrs[args[i]] =3D ret.params[args[i]] =3D args[i+1]; } } ret.objAttrs["classid"] =3D classid; if (mimeType) ret.embedAttrs["type"] =3D mimeType; return ret; } ------=_NextPart_000_00D3_01CC0B12.32205B80--