/* This notice must be untouched at all times.

wz_tooltip.js	 v. 4.12

The latest version is available at
http://www.walterzorn.com
or http://www.devira.com
or http://www.walterzorn.de

Copyright (c) 2002-2007 Walter Zorn. All rights reserved.
Created 1.12.2002 by Walter Zorn (Web: http://www.walterzorn.com )
Last modified: 13.7.2007

Easy-to-use cross-browser tooltips.
Just include the script at the beginning of the <body> section, and invoke
Tip('Tooltip text') from within the desired HTML onmouseover eventhandlers.
No container DIV, no onmouseouts required.
By default, width of tooltips is automatically adapted to content.
Is even capable of dynamically converting arbitrary HTML elements to tooltips
by calling TagToTip('ID_of_HTML_element_to_be_converted') instead of Tip(),
which means you can put important, search-engine-relevant stuff into tooltips.
Appearance of tooltips can be individually configured
via commands passed to Tip() or TagToTip().

Tab Width: 4
LICENSE: LGPL

This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License (LGPL) as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.

This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

For more details on the GNU Lesser General Public License,
see http://www.gnu.org/copyleft/lesser.html
*/

var config = new Object();

var sachgebiete = "<table width=\"300\"><tr><td><p>Bestimmte Wörter kommen nur in einem bestimmten Kontext, einem Sachgebiet, vor.</p><p>Anhand solch eindeutig zuzuordnender Begriffe kann auf das Sachgebiet des ganzen Texts geschlossen werden.</p><p>Bei mehrdeutigen Wörtern, die mehreren Sachgebieten zugeordnet werden könnten, kann so das nicht passende Sachgebiet ausgeschlossen werden. Kommt z.B. das mehrdeutige Wort „Mutter“ in einem Text mit erkanntem Sachgebiet „Technik“ vor, kann die unpassende Variante „Familienmutter“ ausgeschlossen werden.</p><p>Welche Sachgebiete möglich sind, sehen Sie in der Übersicht rechts.</p></td></tr></table>";
var eigennamen = "<table width=\"300\"><tr><td><p>Bei sprechenden Eigennamen, z.B. Herr Kohl, Frau Stein, Herr Fischer, übersetzen herkömmliche Übersetzungsprogramme auch den Namen.</p><p>Personal Translator 2008 ist dagegen so intelligent, diese Wörter als Eigennamen zu erkennen und sie daher nicht zu übersetzen.</p></td></tr></table>";
var smartcorrect = "<table width=\"300\"><tr><td><p>Tippfehler und Rechtschreibfehler passieren sehr leicht, können aber fatale Auswirkungen auf die Übersetzung haben.</p><p>Die neue Funktion SmartCorrect&trade; markiert Fehler im Originaltext nicht nur wie ein herkömmlicher Rechtschreibprüfer, sondern korrigiert sie auch selbsttätig während der Übersetzung.</p><p>Personal Translator erkennt z.B., dass mit &quot;tüxhtig tpipen&quot; eigentlich &quot;tüchtig tippen&quot; gemeint ist, und schon ist die Übersetzung kein Problem mehr.</p></td></tr></table>";
var lfeos = "<table width=\"300\"><tr><td><p>Nicht immer beendet ein Satzende-Punkt einen Satz, bei Aufzählungen beispielsweise endet die Zeile ohne Satzende-Punkt.<br>Dann macht es Sinn, die Funktion &quot;Zeilenumbruch als Satzende&quot; einzustellen.</p></td></tr></table>";

var sachgebiete_en = "<table width=\"300\"><tr><td><p>There are certain words that appear in certain contexts and in certain subject areas.</p><p>By identifying such clearly attributable terms, it then becomes possible to determine the subject area of the entire text.</p><p>Ambiguous words, which could be attributed to several subject areas, can be used to rule out other subject areas. Say, for example, the ambiguous word “seal” appears in a text that is recognized as pertaining to the subject area “nature”. It is then possible to rule out the unsuitable option of “sealant”, a word which has technical connotations. </p><p> A list of possible subject areas is found in the overview on the right. </p></td></tr></table>";
var eigennamen_en = "<table width=\"300\"><tr><td><p>Traditional translation programs tend to translate meaningful proper names such as Mr. Brown, Ms. Stone and Mr. Fisher.</p><p>Personal Translator 2008, on the other hand, is capable of identifying these words as proper names and these words are then ignored in the translation process.</p></td></tr></table>";
var smartcorrect_en = "<table width=\"300\"><tr><td><p>Typos and spelling errors can easily occur, but they can also have disastrous effects on translations.</p><p>The new function SmartCorrect&trade; not only highlights errors in the original text like a traditional spell checker; it also corrects them automatically during the translation process.</p><p>Personal Translator for example, recognizes that \"tretmnedous tpyig\" actually means \"tremendous typing\", and automatically corrects it before translation takes place.</p></td></tr></table>";
var lfeos_en = "<table width=\"300\"><tr><td><p>A period is not the only indicator for the end of a sentence. For example, the lines of a list often end without one.<br>It then makes sense to use the \"End of line = end of sentence\" function.</p></td></tr></table>";

var sachgebiete_fr = "<table width=\"300\"><tr><td><p>Certains termes n’apparaissent que dans certains contextes, certains domaines spécifiques.</p><p>et par ces termes, l’on peu dénoter le domaine ou le contexte de tout un texte.</p><p>Ainsi les termes polysémiques peuvent être différenciés par association à partir de leur contexte.  Ainsi, le terme «mère» qui a plusieurs connotations et significations possibles, agrémenté de «de famille» sera totalement exclu dans un contexte technique, car impropre.</p><p>Dans l’aperçu à droite, vous pouvez voir les domaines entrant en ligne de compte.</p></td></tr></table>";
var eigennamen_fr = "<table width=\"300\"><tr><td><p>Lorsque les noms propres ont aussi une signification comme par exemple pour «Monsieur Bœuf», «Madame Lagrange» ou encore «Monsieur Chiffre», ceux-ci sont également traduits par les logiciels de traduction traditionnels.</p><p>Personal Translator 2008 est par contre tellement futé qu’il les reconnaît en tant que tels et qu’il ne les traduit pas.</p></td></tr></table>";
var smartcorrect_fr = "<table width=\"300\"><tr><td><p>L’on fait très vite des fautes de frappe et d’orthographe. Celles-ci peuvent par contre avoir des conséquences fatales sur les traductions.</p><p>La nouvelle fonction SmartCorrect&trade; surligne non seulement les fautes dans le texte original comme le fait un correcteur d’orthographe, mais les corrige automatiquement également pendant la traduction .</p><p>Personal Translator reconnaît tout de suite de &quot;tüxhtig tpipen&quot; quoi &quot;tüchtig tippen&quot; il s’agit et la traduction ne pose plus aucun problème.</p></td></tr></table>";
var lfeos_fr = "<table width=\"300\"><tr><td><p>Une phrase n’est pas toujours terminée par un point. Comme par exemple lors d’une énumération.br>Il est donc recommandé d’activer la fonction &quot;retour à la ligne comme fin de phrase.&quot; </p></td></tr></table>";

var sachgebiete_it = "<table width=\"300\"><tr><td><p>Determinate parole ricorrono solo in uno specifico contesto, un'area tematica.</p><p>Sulla base di tali concetti univocamente associabili è possibile dedurre l'area tematica dell'intero testo.</p><p>In presenza di parole con più significati che possono essere collegate a più contesti è allo stesso modo possibile escludere l'area tematica inappropriata. Ad esempio, se la parola \"Mutter\" (\"madre\") appare in un testo la cui area tematica riconosciuta è la \"tecnica\", è possibile escludere con certezza la traduzione \"madre di famiglia\", non adatta al contesto.</p><p>Le aree tematiche possibili sono visualizzate nel riepilogo a destra.</p></td></tr></table>";
var eigennamen_it = "<table width=\"300\"><tr><td><p>I nomi propri eloquenti come \"Signor Bianco\", \"Signora Pesce\", \"Signor Natale\", vengono generalmente tradotti dai tradizionali programmi di traduzione.</p><p>Personal Translator 2008 invece è talmente intelligente da riconoscere queste parole come nomi propri e quindi non le traduce.</p></td></tr></table>";
var smartcorrect_it = "<table width=\"300\"><tr><td><p>Gli errori di ortografia e digitazione si verificano con molta facilità e possono avere conseguenze spiacevoli sulla traduzione.</p><p>La nuova funzione SmartCorrect&trade; segnala gli errori nel testo originale come un normale correttore ortografico e in più li corregge automaticamente durante la traduzione.</p><p>Personal Translator riconosce, ad es., che con &quot;scitura coreta&quot; in realtà si intende &quot;scrittura corretta&quot;. La traduzione quindi non rappresenta più un problema.</p></td></tr></table>";
var lfeos_it = "<table width=\"300\"><tr><td><p>Una frase non finisce sempre con un punto. Negli elenchi, ad esempio, la riga può finire senza punto.<br>In tal caso è utile impostare la funzione &quot;Interruzione di riga = fine della frase&quot;.</p></td></tr></table>";

var sachgebiete_es = "<table width=\"300\"><tr><td><p>Determinadas palabras sólo se encuentran en un determinado contexto, en una materia.</p><p>Mediante estos conceptos unívocos puede determinarse la materia a la que pertenece un texto completo.</p><p>Por tanto, cuando se trabaja con palabras polisémicas que pueden hacer referencia a varias materias, es posible descartar otras con las que no se corresponden. Por ejemplo, si encontramos la palabra polisémica \"madre\" en un texto técnico, podemos excluir el sentido de \"madre de familia\", que no cuadra en el conjunto.</p><p>Para saber qué materias son posibles, basta con consultar el resumen que se encuentra a la derecha.</p></td></tr></table>";
var eigennamen_es = "<table width=\"300\"><tr><td><p>Los traductores automáticos convencionales suelen traducir los nombres propios como señor Kohl, señora Stein o señor Fischer cuando los encuentran en un texto.</p><p>Personal Translator 2008 es, por el contrario, tan inteligente que reconoce estas palabras como nombres propios y no las traduce.</p></td></tr></table>";
var smartcorrect_es = "<table width=\"300\"><tr><td><p>Los errores tipográficos y ortográficos, si bien se producen con facilidad, podrían provocar una catástrofe en una traducción.</p><p>La nueva función SmartCorrect&trade; resalta los errores en el texto original como cualquier corrector ortográfico tradicional, pero con la ventaja de corregirlos automáticamente durante la traducción.</p><p>Personal Translator reconoce, por ejemplo, que con &quot;escirbir bine&quot; realmente se quiere decir &quot;escribir bien&quot;, y así la traducción ya no es un problema.</p></td></tr></table>";
var lfeos_es = "<table width=\"300\"><tr><td><p>No todas las frases terminan con un signo de puntuación; por ejemplo, las listas con viñetas pueden no llevarlos.<br>Por eso resulta muy útil utilizar la función &quot;Salto de línea es final de frase&quot;.</p></td></tr></table>";

var sachgebiete_pt = "<table width=\"300\"><tr><td><p>Determinadas palavras surgem apenas em determinado contexto, em uma área específica.</p><p>Com base nestes termos tão claramente atribuídos, é possível determinar a área temática de todo o texto.</p><p>No caso de palavras ambíguas, que possam ser atribuídas a mais do que uma área temática, não será possível determinar a área temática mais apropriada. Caso surja, por ex., a palavra ambígua \"macaco\" em um texto cuja área temática seja claramente \"técnica\", é possível excluir a variante inadequada \"macaco selvagem\".</p><p>Na visão geral à direita, você pode ver quais as áreas temáticas disponíveis.</p></td></tr></table>";
var eigennamen_pt = "<table width=\"300\"><tr><td><p>No caso de nomes próprios como Senhor Pinheiro, Senhora Silva ou Senhor Valente, os programas de tradução convencionais traduzem também os nomes.</p><p>O Personal Translator 2008, pelo contrário, é tão inteligente que reconhece estas palavras como nomes próprios e, portanto, não as traduz.</p></td></tr></table>";
var smartcorrect_pt = "<table width=\"300\"><tr><td><p>Erros de digitação e erros ortográficos podem ocorrer muito facilmente, e podem ter conseqüências graves na tradução.</p><p>A nova função SmartCorrect&trade; não se limita a marcar os erros no texto original como um corretor ortográfico convencional, mas corrige-os também automaticamente durante a tradução.</p><p>O Personal Translator reconhece que com &quot;digiotar rapiddoo&quot; você queria realmente dizer &quot;digitar rápido&quot; e a tradução já não representa qualquer problema.</p></td></tr></table>";
var lfeos_pt = "<table width=\"300\"><tr><td><p>Nem sempre um ponto final termina uma frase, em enumerações, por exemplo, a linha termina sem ponto final.<br>Nesse caso, faz sentido, configurar a função &quot;Quebra de linha como final de frase&quot;.</p></td></tr></table>";

var sachgebiete_nl = "<table width=\"300\"><tr><td><p>Bepaalde woorden komen alleen in een bepaald verband of binnen een bepaald vakgebied voor.</p><p>Uit zulke ondubbelzinnig toewijsbare termen kan het hele vakgebied worden afgeleid.</p><p>Bij woorden die voor verschillende uitlegging vatbaar zijn en aan meerdere vakgebieden toegewezen zouden kunnen worden, kan op die manier het niet van toepassing zijnde vakgebied worden uitgesloten. Wanneer bijvoorbeeld in het Duits het dubbelzinnige woord „Mutter“ in een technische tekst voorkomt, kan de onpassende variant in de strekking van „moeder van een gezin“ worden uitgesloten. (Mutter kann in het Duits „moer“ en „moeder“ betekenen).</p><p>Welke vakgebieden mogelijk zijn ziet u in een overzicht hier rechts.</p></td></tr></table>";
var eigennamen_nl = "<table width=\"300\"><tr><td><p>Bij sprekende namen, bijv. meneer Kool, mevrouw Steen, meneer Visser, vertalen de vertalingsprogramma´s van tot dusver ook de namen.</p><p>Personal Translator 2008 is daarentegen zo intelligent dat het deze woorden als naam herkent en ze daarom niet vertaalt.</p></td></tr></table>";
var smartcorrect_nl = "<table width=\"300\"><tr><td><p>Typfouten en spellingsfouten gebeuren heel snel, kunnen echter fatale gevolgen voor de vertaling hebben.</p><p>De nieuwe functie SmartCorrect&trade; markeert de fouten in de brontekst niet alleen als een gewone spellingscorrector, maar corrigeert ze ook vanzelf tijdens de vertaling.</p><p>Personal Translator herkent bijv. met &quot;opneiuw invvoeren&quot; eigenlijk &quot;opnieuw invoeren&quot; is bedoeld en dan is de vertaling al geen probleem meer.</p></td></tr></table>";
var lfeos_nl = "<table width=\"300\"><tr><td><p>Niet altijd betekent een punt het einde van een zin, want bijvoorbeeld eindigt een regel bij opsommingen zonder punt.<br>Dan is aan te bevelen om de functie &quot;Afbreken regel als Regeleinde&quot; in te stellen.</p></td></tr></table>";

var sachgebiete_zh = "<table width=\"300\"><tr><td><p>特定的词只会出现在一个专业领域的一篇特定上下文里。</p><p>鉴于这些唯一意义的被整理过的概念可以决定整篇文章的主题领域.</p><p>对于多义词，会被归于多个主题领域，这样就可以把不相关的主题领域排除在外。例如，多义词„血（钱）“在一个已经被确定的主题领域„金融“中出现,那么另一个不合适的选项„医学中的血“就会被排除。</p><p>有哪些可能的主题领域呢？请看右边的一览表。</p></td></tr></table>";
var eigennamen_zh = "<table width=\"300\"><tr><td><p>在专有名词中，例如Mrs. Stone，Mr. Fox也会被传统的翻译程序翻译成名词，例如Stone-->石头，Fox-->狐狸。</p><p>个人翻译器 2008是如此的智能，以上所说的词都会被作为人名识别出来，并且音译过来。</p></td></tr></table>";
var smartcorrect_zh = "<table width=\"300\"><tr><td><p>笔误和白字会经常出现，但是却会给翻译的效果造成灾难性的影响。</p><p>最新的功能智能修改和交换不仅会像传统的拼写检查一样标记错误，而是在翻译的过程中自动的修改过来。</p><p>个人翻译器能识别，例如,输入&quot;tüxhtig &quot;，原本是打算输入 &quot;tüchtig&quot;的 ,这样纠正后的内容就不会影响到翻译了。</p></td></tr></table>";
var lfeos_zh = "<table width=\"300\"><tr><td><p>句末的标点不一定就总是意味着句子的结束，例如，在列举的时候，行末没有句末标点。<br>那么&quot;行末也是句末&quot; 这项功能就十分用了。</p></td></tr></table>";

var vorlesen = "<p>Klicken Sie hier zum Vorlesen!</p>";
var umgewandelt = "<p>Schild in Text umgewandelt</p>";
var schild = "<p>Fotografiertes Schild</p>";

var simpleparse_de = "&lt;html&gt;<br>&lt;head&gt;<br>&lt;title&gt;&lt;/title&gt;<br>&lt;/head&gt;<br>&lt;body&gt;<br>&emsp;&emsp;&lt;read&gt;<br>&emsp;&emsp;&lt;p&gt;Dieser Text wird vom Voice Reader Web vorgelesen,<br>&emsp;&emsp;weil er innerhalb von den Tags 'read' steht.&lt;/p&gt;<br>&emsp;&emsp;&lt;/read&gt;<br>&emsp;&emsp;&lt;p&gt;Dieser Text wird nicht vorgelesen.&lt;/p&gt;<br>&lt;/body&gt;<br>&lt;/html&gt;<br><br><b>Vorgelesen wird: <br>Dieser Text wird vom Voice Reader Web vorgelesen, weil er<br> innerhalb von den Tags 'read' steht."
var simpleparse_en = "&lt;html&gt;<br>&lt;head&gt;<br>&lt;title&gt;&lt;/title&gt;<br>&lt;/head&gt;<br>&lt;body&gt;<br>&emsp;&emsp;&lt;read&gt;<br>&emsp;&emsp;&lt;p&gt;This text will be read by Voice Reader Web,<br>&emsp;&emsp;because it appears within the 'read' tag.&lt;/p&gt;<br>&emsp;&emsp;&lt;/read&gt;<br>&emsp;&emsp;&lt;p&gt;This will be not read.&lt;/p&gt;<br>&lt;/body&gt;<br>&lt;/html&gt;<br><br><b>Voice Reader Web reads: <br>This text will be read by Voice Reader Web, because it appears <br>within the 'read' tag."

var elementname_de = "<b>Alles, was innerhalb von den Tags 'h1, div, p' steht, wird vorgelesen:</b><br><br>&lt;html&gt;<br>&lt;head&gt;<br>&lt;title&gt;&lt;/title&gt;<br>&lt;/head&gt;<br>&lt;body&gt;<br>&emsp;&emsp;&lt;h1&gt;Überschrift.&lt;/h1&gt;<br>&emsp;&emsp;&lt;p&gt;Dieser Text wird vom Voice Reader Web vorgelesen. Er liest <br>&emsp;&emsp;alles, was innerhalb von den Tags 'div', 'h1', 'p' steht.&lt;/p&gt;<br>&emsp;&emsp;&lt;div&gt;Das hier wird auch vorgelesen.&lt;/div&gt;<br>&emsp;&emsp;Dieser Text wird nicht vorgelesen.<br>&lt;/body&gt;<br>&lt;/html&gt;<br><br><b>Vorgelesen wird:</b><br><b>Überschrift. <br>Dieser Text wird vom Voice Reader Web vorgelesen. Er liest alles, <br>was innerhalb von den Tags 'div', 'h1', 'p' steht. Das hier wird auch <br>vorgelesen.</b>";
var elementname_en = "<b>The text appearing within 'h1', 'div', 'p' tags will be read:</b><br><br>&lt;html&gt;<br>&lt;head&gt;<br>&lt;title&gt;&lt;/title&gt;<br>&lt;/head&gt;<br>&lt;body&gt;<br>&emsp;&emsp;&lt;h1&gt;Headline.&lt;/h1&gt;<br>&emsp;&emsp;&lt;p&gt;This text will be read by Voice Reader Web. It reads <br>&emsp;&emsp;the content within the Tags 'div', 'h1', 'p'.&lt;/p&gt;<br>&emsp;&emsp;&lt;div&gt;This will be read, too.&lt;/div&gt;<br>&emsp;&emsp;This text will be not read.<br>&lt;/body&gt;<br>&lt;/html&gt;<br><br><b>Voice Reader Web reads:</b><br><b>Headline. This text will be read by Voice Reader Web. <br>It reads the content within the tags 'div', 'h1', 'p'. This will be <br>read, too.</b>";

var elementclass_de = "<b>Alles, was innerhalb von den Tags der Klasse 'read' und 'public' steht, <br>wird vorgelesen:</b><br><br>&lt;html&gt;<br>&lt;head&gt;<br>&lt;title&gt;&lt;/title&gt;<br>&lt;/head&gt;<br>&lt;body&gt;<br>&emsp;&emsp;&lt;h1 class=&quot;read&quot;&gt;Überschrift.&lt;/h1&gt;<br>&emsp;&emsp;&lt;p class=&quot;read&quot;&gt;Dieser Text wird vom Voice Reader Web vorgelesen. <br>&emsp;&emsp;Er liest alles, was innerhalb von den Tags der Klasse 'read' <br>&emsp;&emsp;und 'public' steht.&lt;/p&gt;<br>&emsp;&emsp;&lt;p class=&quot;public&quot;&gt;Das hier wird auch vorgelesen.&lt;/p&gt;<br>&emsp;&emsp;&lt;p&gt;Dieser Text wird nicht vorgelesen.&lt;/p&gt;<br>&lt;/body&gt;<br>&lt;/html&gt;<br><b>Vorgelesen wird:</b><br><b>Überschrift. Dieser Text wird vom Voice Reader Web vorgelesen. Er liest alles, <br>was innerhalb von Tags der Klasse 'read' und 'public' steht. Das hier wird auch <br>vorgelesen.</b>";
var elementclass_en = "<b>The text appearing within the tags of class 'read' and 'public'will be read:</b><br><br>&lt;html&gt;<br>&lt;head&gt;<br>&lt;title&gt;&lt;/title&gt;<br>&lt;/head&gt;<br>&lt;body&gt;<br>&emsp;&emsp;&lt;h1 class=&quot;read&quot;&gt;Headline.&lt;/h1&gt;<br>&emsp;&emsp;&lt;p class=&quot;read&quot;&gt;This text will be read by Voice Reader Web. <br>&emsp;&emsp;It reads the content within the tags of class 'read' and 'public'.&lt;/p&gt;<br>&emsp;&emsp;&lt;p class=&quot;public&quot;&gt;This will be read, too.&lt;/p&gt;<br>&emsp;&emsp;&lt;p&gt;This text will be not read.&lt;/p&gt;<br>&lt;/body&gt;<br>&lt;/html&gt;<br><b>Voice Reader Web reads:</b><br><b>Headline. This text will be read by Voice Reader Web. It reads the content <br>within the tags of class 'read' and 'public'. This will be read, too.</b>";

var exclelementname_de = "<b>Wir legen fest, daß nur das, was innerhalb von den Tags 'h1', 'p' steht, vorgelesen wird.<br>Alles, was innerhalb vom Tag 'div' steht, wird also nicht vorgelesen:</b><br><br>&lt;html&gt;<br>&lt;head&gt;<br>&lt;title&gt;&lt;/title&gt;<br>&lt;/head&gt;<br>&lt;body&gt;<br>&emsp;&emsp;&lt;h1&gt;Überschrift.&lt;/h1&gt;<br>&emsp;&emsp;&lt;p&gt;Dieser Text wird vom Voice Reader Web vorgelesen. Er liest alles, <br>was innerhalb von Tags 'h1', 'p' steht.&lt;/p&gt;<br>&emsp;&emsp;&lt;p&gt;Das hier wird auch vorgelesen.&lt;/p&gt;<br>&emsp;&emsp;&lt;div&gt;Dieser Text wird nicht vorgelesen.&lt;/div&gt;<br>&lt;/body&gt;<br>&lt;/html&gt;<br><br><b>Vorgelesen wird:</b><br><b>Überschrift. Dieser Text wird vom Voice Reader Web vorgelesen. <br>Er liest alles, was innerhalb von den Tags 'h1', 'p' steht. Das hier <br>wird auch vorgelesen.</b>";
var exclelementname_en = "<b>The Text appearing within 'h1', 'p' elements willbe read out.<br>So, all content appearing within 'div' tag will be not read:</b><br><br>&lt;html&gt;<br>&lt;head&gt;<br>&lt;title&gt;&lt;/title&gt;<br>&lt;/head&gt;<br>&lt;body&gt;<br>&emsp;&emsp;&lt;h1&gt;Headline.&lt;/h1&gt;<br>&emsp;&emsp;&lt;p&gt;This text will be read by Voice Reader Web. <br>&emsp;&emsp;It reads the content within the Tags 'h1', 'p'.&lt;/p&gt;<br>&emsp;&emsp;&lt;p&gt;This will be read, too.&lt;/p&gt;<br>&emsp;&emsp;&lt;div&gt;This text will be not read.&lt;/div&gt;<br>&lt;/body&gt;<br>&lt;/html&gt;<br><br><b>Voice Reader Web reads:</b><br><b>Headline. This text will be read by Voice Reader Web. <br>It reads the content within the Tags 'h1', 'p'. This will be <br>read, too.</b>";

var exclelementclass_de = "<b>Wir legen fest, daß alles, was innerhalb von den Tags 'h1', 'p' steht, <br>vorgelesen wird, wenn diese Tags nicht der Klasse 'dont_read' angehören:</b><br><br>&lt;html&gt;<br>&lt;head&gt;<br>&lt;title&gt;&lt;/title&gt;<br>&lt;/head&gt;<br>&lt;body&gt;<br>&emsp;&emsp;&lt;h1&gt;Überschrift.&lt;/h1&gt;<br>&emsp;&emsp;&lt;p&gt;Dieser Text wird vom Voice Reader Web vorgelesen. Er liest alles, <br>&emsp;&emsp;was innerhalb von den Tags 'h1', 'p' steht.&lt;/p&gt;<br>&emsp;&emsp;&lt;p&gt;Das hier wird auch vorgelesen.&lt;/p&gt;<br>&emsp;&emsp;&lt;p class=&quot;dont_read&quot;&gt;Dieser Text wird nicht vorgelesen.&lt;/p&gt;<br>&lt;/body&gt;<br>&lt;/html&gt;<br><br><b>Vorgelesen wird:</b><br><b>Überschrift. Dieser Text wird vom Voice Reader Web vorgelesen. Er liest alles, <br>was innerhalb von den Tags 'h1', 'p' steht. Das hier wird auch vorgelesen.</b>";
var exclelementclass_en = "<b>The Text appearing within 'h1', 'p' elements willbe read out, <br>if these elements aren't of class 'dont_read':</b><br><br>&lt;html&gt;<br>&lt;head&gt;<br>&lt;title&gt;&lt;/title&gt;<br>&lt;/head&gt;<br>&lt;body&gt;<br>&emsp;&emsp;&lt;h1&gt;Headline.&lt;/h1&gt;<br>&emsp;&emsp;&lt;p&gt;This text will be read by Voice Reader Web. It reads the content <br>&emsp;&emsp;within the Tags 'h1', 'p'.&lt;/p&gt;<br>&emsp;&emsp;&lt;p&gt;This will be read, too.&lt;/p&gt;<br>&emsp;&emsp;&lt;p class=&quot;dont_read&quot;&gt;This text will be not read.&lt;/p&gt;<br>&lt;/body&gt;<br>&lt;/html&gt;<br><br><b>Voice Reader Web reads:</b><br><b>Headline. This text will be read by Voice Reader Web. It reads the content <br>within the Tags 'h1', 'p'. This will be read, too.</b>";

//===================  GLOBAL TOOPTIP CONFIGURATION  =========================//
var  tt_Debug	= true		// false or true - recommended: false once you release your page to the public
var  tt_Enabled	= true		// Allows to (temporarily) suppress tooltips, e.g. by providing the user with a button that sets this global variable to false
var  TagsToTip	= true		// false or true - if true, the script is capable of converting HTML elements to tooltips

// For each of the following config variables there exists a command, which is
// just the variablename in uppercase, to be passed to Tip() or TagToTip() to
// configure tooltips individually. Individual commands override global
// configuration. Order of commands is arbitrary.
// Example: onmouseover="Tip('Tooltip text', LEFT, true, BGCOLOR, '#FF9900', FADEIN, 400)"

config. Above			= false 	// false or true - tooltip above mousepointer?
config. BgColor 		= '#ffffe1' // Background color
config. BgImg			= ''		// Path to background image, none if empty string ''
config. BorderColor 	= '#000000'
config. BorderStyle 	= 'solid'	// Any permitted CSS value, but I recommend 'solid', 'dotted' or 'dashed'
config. BorderWidth 	= 1
config. CenterMouse 	= false 	// false or true - center the tip horizontally below (or above) the mousepointer
config. ClickClose		= false 	// false or true - close tooltip if the user clicks somewhere
config. CloseBtn		= false 	// false or true - closebutton in titlebar
config. CloseBtnColors	= ['#990000', '#FFFFFF', '#DD3333', '#FFFFFF']	  // [Background, text, hovered background, hovered text] - use empty strings '' to inherit title colors
config. CloseBtnText	= '&nbsp;X&nbsp;'	// Close button text (may also be an image tag)
config. CopyContent		= true		// When converting a HTML element to a tooltip, copy only the element's content, rather than converting the element by its own
config. Delay			= 400		// Time span in ms until tooltip shows up
config. Duration		= 0 		// Time span in ms after which the tooltip disappears; 0 for infinite duration
config. FadeIn			= 0 		// Fade-in duration in ms, e.g. 400; 0 for no animation
config. FadeOut 		= 0
config. FadeInterval	= 30		// Duration of each fade step in ms (recommended: 30) - shorter is smoother but causes more CPU-load
config. Fix 			= null		// Fixated position - x- an y-oordinates in brackets, e.g. [210, 480], or null for no fixation
config. FollowMouse		= true		// false or true - tooltip follows the mouse
config. FontColor		= '#000000'
config. FontFace		= 'Verdana,Geneva,sans-serif'
config. FontSize		= '8pt' 	// E.g. '9pt' or '12px' - unit is mandatory
config. FontWeight		= 'normal'	// 'normal' or 'bold';
config. Left			= false 	// false or true - tooltip on the left of the mouse
config. OffsetX 		= 14		// Horizontal offset of left-top corner from mousepointer
config. OffsetY 		= 8 		// Vertical offset
config. Opacity 		= 100		// Integer between 0 and 100 - opacity of tooltip in percent
config. Padding 		= 3 		// Spacing between border and content
config. Shadow			= false 	// false or true
config. ShadowColor 	= '#C0C0C0'
config. ShadowWidth 	= 5
config. Sticky			= false 	// Do NOT hide tooltip on mouseout? false or true
config. TextAlign		= 'left'	// 'left', 'right' or 'justify'
config. Title			= ''		// Default title text applied to all tips (no default title: empty string '')
config. TitleAlign		= 'left'	// 'left' or 'right' - text alignment inside the title bar
config. TitleBgColor	= ''		// If empty string '', BorderColor will be used
config. TitleFontColor	= '#ffffff'	// Color of title text - if '', BgColor (of tooltip body) will be used
config. TitleFontFace	= ''		// If '' use FontFace (boldified)
config. TitleFontSize	= ''		// If '' use FontSize
config. Width			= 0      
//=======  END OF TOOLTIP CONFIG, DO NOT CHANGE ANYTHING BELOW  ==============//




//======================  PUBLIC  ============================================//
function Tip()
{
	tt_Tip(arguments, null);
        
}
function TagToTip()
{
	if(TagsToTip)
	{
		var t2t = tt_GetElt(arguments[0]);
		if(t2t)
			tt_Tip(arguments, t2t);
	}
}

//==================  PUBLIC EXTENSION API	==================================//
// Extension eventhandlers currently supported:
// OnLoadConfig, OnCreateContentString, OnSubDivsCreated, OnShow, OnMoveBefore,
// OnMoveAfter, OnHideInit, OnHide, OnKill

var tt_aElt = new Array(10), // Container DIV, outer title & body DIVs, inner title & body TDs, closebutton SPAN, shadow DIVs, and IFRAME to cover windowed elements in IE
tt_aV = new Array(),	// Caches and enumerates config data for currently active tooltip
tt_sContent,			// Inner tooltip text or HTML
tt_scrlX = 0, tt_scrlY = 0,
tt_musX, tt_musY,
tt_over,
tt_x, tt_y, tt_w, tt_h; // Position, width and height of currently displayed tooltip

function tt_Extension()
{
	tt_ExtCmdEnum();
	tt_aExt[tt_aExt.length] = this;
	return this;
}
function tt_SetTipPos(x, y)
{
	var css = tt_aElt[0].style;

	tt_x = x;
	tt_y = y;
	css.left = x + "px";
	css.top = y + "px";
	if(tt_ie56)
	{
		var ifrm = tt_aElt[tt_aElt.length - 1];
		if(ifrm)
		{
			ifrm.style.left = css.left;
			ifrm.style.top = css.top;
		}
	}
}
function tt_Hide()
{
	if(tt_db && tt_iState)
	{
		if(tt_iState & 0x2)
		{
			tt_aElt[0].style.visibility = "hidden";
			tt_ExtCallFncs(0, "Hide");
		}
		tt_tShow.EndTimer();
		tt_tHide.EndTimer();
		tt_tDurt.EndTimer();
		tt_tFade.EndTimer();
		if(!tt_op && !tt_ie)
		{
			tt_tWaitMov.EndTimer();
			tt_bWait = false;
		}
		if(tt_aV[CLICKCLOSE])
			tt_RemEvtFnc(document, "mouseup", tt_HideInit);
		tt_AddRemOutFnc(false);
		tt_ExtCallFncs(0, "Kill");
		// In case of a TagToTip tooltip, hide converted DOM node and
		// re-insert it into document
		if(tt_t2t && !tt_aV[COPYCONTENT])
		{
			tt_t2t.style.display = "none";
			tt_MovDomNode(tt_t2t, tt_aElt[6], tt_t2tDad);
		}
		tt_iState = 0;
		tt_over = null;
		tt_ResetMainDiv();
		if(tt_aElt[tt_aElt.length - 1])
			tt_aElt[tt_aElt.length - 1].style.display = "none";
	}
}
function tt_GetElt(id)
{
	return(document.getElementById ? document.getElementById(id)
			: document.all ? document.all[id]
			: null);
}
function tt_GetDivW(el)
{
	return(el ? (el.offsetWidth || el.style.pixelWidth || 0) : 0);
}
function tt_GetDivH(el)
{
	return(el ? (el.offsetHeight || el.style.pixelHeight || 0) : 0);
}
function tt_GetScrollX()
{
	return(window.pageXOffset || (tt_db ? (tt_db.scrollLeft || 0) : 0));
}
function tt_GetScrollY()
{
	return(window.pageYOffset || (tt_db ? (tt_db.scrollTop || 0) : 0));
}
function tt_GetClientW()
{
	return(document.body && (typeof(document.body.clientWidth) != tt_u) ? document.body.clientWidth
			: (typeof(window.innerWidth) != tt_u) ? window.innerWidth
			: tt_db ? (tt_db.clientWidth || 0)
			: 0);
}
function tt_GetClientH()
{
	// Exactly this order seems to yield correct values in all major browsers
	return(document.body && (typeof(document.body.clientHeight) != tt_u) ? document.body.clientHeight
			: (typeof(window.innerHeight) != tt_u) ? window.innerHeight
			: tt_db ? (tt_db.clientHeight || 0)
			: 0);
}
function tt_GetEvtX(e)
{
	return (e ? ((typeof(e.pageX) != tt_u) ? e.pageX : (e.clientX + tt_scrlX)) : 0);
}
function tt_GetEvtY(e)
{
	return (e ? ((typeof(e.pageY) != tt_u) ? e.pageY : (e.clientY + tt_scrlY)) : 0);
}
function tt_AddEvtFnc(el, sEvt, PFnc)
{
	if(el)
	{
		if(el.addEventListener)
			el.addEventListener(sEvt, PFnc, false);
		else
			el.attachEvent("on" + sEvt, PFnc);
	}
}
function tt_RemEvtFnc(el, sEvt, PFnc)
{
	if(el)
	{
		if(el.removeEventListener)
			el.removeEventListener(sEvt, PFnc, false);
		else
			el.detachEvent("on" + sEvt, PFnc);
	}
}

//======================  PRIVATE  ===========================================//
var tt_aExt = new Array(),	// Array of extension objects

tt_db, tt_op, tt_ie, tt_ie56, tt_bBoxOld,	// Browser flags
tt_body,
tt_flagOpa, 			// Opacity support: 1=IE, 2=Khtml, 3=KHTML, 4=Moz, 5=W3C
tt_maxPosX, tt_maxPosY,
tt_iState = 0,			// Tooltip active |= 1, shown |= 2, move with mouse |= 4
tt_opa, 				// Currently applied opacity
tt_bJmpVert,			// Tip above mouse (or ABOVE tip below mouse)
tt_t2t, tt_t2tDad,		// Tag converted to tip, and its parent element in the document
tt_elDeHref,			// The tag from which Opera has removed the href attribute
// Timer
tt_tShow = new Number(0), tt_tHide = new Number(0), tt_tDurt = new Number(0),
tt_tFade = new Number(0), tt_tWaitMov = new Number(0),
tt_bWait = false,
tt_u = "undefined";


function tt_Init()
{
	tt_MkCmdEnum();
	// Send old browsers instantly to hell
	if(!tt_Browser() || !tt_MkMainDiv())
		return;
	tt_IsW3cBox();
	tt_OpaSupport();
	tt_AddEvtFnc(document, "mousemove", tt_Move);
	// In Debug mode we search for TagToTip() calls in order to notify
	// the user if they've forgotten to set the TagsToTip config flag
	if(TagsToTip || tt_Debug)
		tt_SetOnloadFnc();
	tt_AddEvtFnc(window, "scroll",
		function()
		{
			tt_scrlX = tt_GetScrollX();
			tt_scrlY = tt_GetScrollY();
			if(tt_iState && !(tt_aV[STICKY] && (tt_iState & 2)))
				tt_HideInit();
		} );
	// Ensure the tip be hidden when the page unloads
	tt_AddEvtFnc(window, "unload", tt_Hide);
	tt_Hide();
}
// Creates command names by translating config variable names to upper case
function tt_MkCmdEnum()
{
	var n = 0;
	for(var i in config)
		eval("window." + i.toString().toUpperCase() + " = " + n++);
	tt_aV.length = n;
}
function tt_Browser()
{
	var n, nv, n6, w3c;

	n = navigator.userAgent.toLowerCase(),
	nv = navigator.appVersion;
	tt_op = (document.defaultView && typeof(eval("w" + "indow" + "." + "o" + "p" + "er" + "a")) != tt_u);
	tt_ie = n.indexOf("msie") != -1 && document.all && !tt_op;
	if(tt_ie)
	{
		var ieOld = (!document.compatMode || document.compatMode == "BackCompat");
		tt_db = !ieOld ? document.documentElement : (document.body || null);
		if(tt_db)
			tt_ie56 = parseFloat(nv.substring(nv.indexOf("MSIE") + 5)) >= 5.5
					&& typeof document.body.style.maxHeight == tt_u;
	}
	else
	{
		tt_db = document.documentElement || document.body ||
				(document.getElementsByTagName ? document.getElementsByTagName("body")[0]
				: null);
		if(!tt_op)
		{
			n6 = document.defaultView && typeof document.defaultView.getComputedStyle != tt_u;
			w3c = !n6 && document.getElementById;
		}
	}
	tt_body = (document.getElementsByTagName ? document.getElementsByTagName("body")[0]
				: (document.body || null));
	if(tt_ie || n6 || tt_op || w3c)
	{
		if(tt_body && tt_db)
		{
			if(document.attachEvent || document.addEventListener)
				return true;
		}
		else
			tt_Err("wz_tooltip.js must be included INSIDE the body section,"
					+ " immediately after the opening <body> tag.");
	}
	tt_db = null;
	return false;
}
function tt_MkMainDiv()
{
	// Create the tooltip DIV
	if(tt_body.insertAdjacentHTML)
		tt_body.insertAdjacentHTML("afterBegin", tt_MkMainDivHtm());
	else if(typeof tt_body.innerHTML != tt_u && document.createElement && tt_body.appendChild)
		tt_body.appendChild(tt_MkMainDivDom());
	// FireFox Alzheimer bug
	if(window.tt_GetMainDivRefs && tt_GetMainDivRefs())
		return true;
	tt_db = null;
	return false;
}
function tt_MkMainDivHtm()
{
	return('<div id="WzTtDiV"></div>' +
			(tt_ie56 ? ('<iframe id="WzTtIfRm" src="javascript:false" scrolling="no" frameborder="0" style="filter:Alpha(opacity=0);position:absolute;top:0px;left:0px;display:none;"></iframe>')
			: ''));
}
function tt_MkMainDivDom()
{
	var el = document.createElement("div");
	if(el)
		el.id = "WzTtDiV";
	return el;
}
function tt_GetMainDivRefs()
{
	tt_aElt[0] = tt_GetElt("WzTtDiV");
	if(tt_ie56 && tt_aElt[0])
	{
		tt_aElt[tt_aElt.length - 1] = tt_GetElt("WzTtIfRm");
		if(!tt_aElt[tt_aElt.length - 1])
			tt_aElt[0] = null;
	}
	if(tt_aElt[0])
	{
		var css = tt_aElt[0].style;

		css.visibility = "hidden";
		css.position = "absolute";
		css.overflow = "hidden";
		return true;
	}
	return false;
}
function tt_ResetMainDiv()
{
	var w = (window.screen && screen.width) ? screen.width : 10000;

	tt_SetTipPos(-w, 0);
	tt_aElt[0].innerHTML = "";
	tt_aElt[0].style.width = (w - 1) + "px";
}
function tt_IsW3cBox()
{
	var css = tt_aElt[0].style;

	css.padding = "10px";
	css.width = "40px";
	tt_bBoxOld = (tt_GetDivW(tt_aElt[0]) == 40);
	css.padding = "0px";
	tt_ResetMainDiv();
}
function tt_OpaSupport()
{
	var css = tt_body.style;

	tt_flagOpa = (typeof(css.filter) != tt_u) ? 1
				: (typeof(css.KhtmlOpacity) != tt_u) ? 2
				: (typeof(css.KHTMLOpacity) != tt_u) ? 3
				: (typeof(css.MozOpacity) != tt_u) ? 4
				: (typeof(css.opacity) != tt_u) ? 5
				: 0;
}
// Ported from http://dean.edwards.name/weblog/2006/06/again/
// (Dean Edwards et al.)
function tt_SetOnloadFnc()
{
	tt_AddEvtFnc(document, "DOMContentLoaded", tt_HideSrcTags);
	tt_AddEvtFnc(window, "load", tt_HideSrcTags);
	if(tt_body.attachEvent)
		tt_body.attachEvent("onreadystatechange",
			function() {
				if(tt_body.readyState == "complete")
					tt_HideSrcTags();
			} );
	if(/WebKit|KHTML/i.test(navigator.userAgent))
	{
		var t = setInterval(function() {
					if(/loaded|complete/.test(document.readyState))
					{
						clearInterval(t);
						tt_HideSrcTags();
					}
				}, 10);
	}
}
function tt_HideSrcTags()
{
	if(!window.tt_HideSrcTags || window.tt_HideSrcTags.done)
		return;
	window.tt_HideSrcTags.done = true;
	if(!tt_HideSrcTagsRecurs(tt_body))
		tt_Err("To enable the capability to convert HTML elements to tooltips,"
				+ " you must set TagsToTip in the global tooltip configuration"
				+ " to true.");
}
function tt_HideSrcTagsRecurs(dad)
{
	var a, ovr, asT2t;

	// Walk the DOM tree for tags that have an onmouseover attribute
	// containing a TagToTip('...') call.
	// (.childNodes first since .children is bugous in Safari)
	a = dad.childNodes || dad.children || null;
	for(var i = a ? a.length : 0; i;)
	{--i;
		if(!tt_HideSrcTagsRecurs(a[i]))
			return false;
		ovr = a[i].getAttribute ? a[i].getAttribute("onmouseover")
				: (typeof a[i].onmouseover == "function") ? a[i].onmouseover
				: null;
		if(ovr)
		{
			asT2t = ovr.toString().match(/TagToTip\s*\(\s*'[^'.]+'\s*[\),]/);
			if(asT2t && asT2t.length)
			{
				if(!tt_HideSrcTag(asT2t[0]))
					return false;
			}
		}
	}
	return true;
}
function tt_HideSrcTag(sT2t)
{
	var id, el;

	// The ID passed to the found TagToTip() call identifies an HTML element
	// to be converted to a tooltip, so hide that element
	id = sT2t.replace(/.+'([^'.]+)'.+/, "$1");
	el = tt_GetElt(id);
	if(el)
	{
		if(tt_Debug && !TagsToTip)
			return false;
		else
			el.style.display = "none";
	}
	else
		tt_Err("Invalid ID\n'" + id + "'\npassed to TagToTip()."
				+ " There exists no HTML element with that ID.");
	return true;
}
function tt_Tip(arg, t2t)
{
	if(!tt_db)
		return;
	if(tt_iState)
		tt_Hide();
	if(!tt_Enabled)
		return;
	tt_t2t = t2t;
	if(!tt_ReadCmds(arg))
		return;
	tt_iState = 0x1 | 0x4;
	tt_AdaptConfig1();
	tt_MkTipContent(arg);
	tt_MkTipSubDivs();
	tt_FormatTip();
	tt_bJmpVert = false;
	tt_maxPosX = tt_GetClientW() + tt_scrlX - tt_w - 1;
	tt_maxPosY = tt_GetClientH() + tt_scrlY - tt_h - 1;
	tt_AdaptConfig2();
	// We must fake the first mousemove in order to ensure the tip
	// be immediately shown and positioned
	tt_Move();
	tt_ShowInit();
}
function tt_ReadCmds(a)
{
	var i;

	// First load the global config values, to initialize also values
	// for which no command has been passed
	i = 0;
	for(var j in config)
		tt_aV[i++] = config[j];
	// Then replace each cached config value for which a command has been
	// passed (ensure the # of command args plus value args be even)
	if(a.length & 1)
	{
		for(i = a.length - 1; i > 0; i -= 2)
			tt_aV[a[i - 1]] = a[i];
		return true;
	}
	tt_Err("Incorrect call of Tip() or TagToTip().\n"
			+ "Each command must be followed by a value.");
	return false;
}
function tt_AdaptConfig1()
{
	tt_ExtCallFncs(0, "LoadConfig");
	// Inherit unspecified title formattings from body
	if(!tt_aV[TITLEBGCOLOR].length)
		tt_aV[TITLEBGCOLOR] = tt_aV[BORDERCOLOR];
	if(!tt_aV[TITLEFONTCOLOR].length)
		tt_aV[TITLEFONTCOLOR] = tt_aV[BGCOLOR];
	if(!tt_aV[TITLEFONTFACE].length)
		tt_aV[TITLEFONTFACE] = tt_aV[FONTFACE];
	if(!tt_aV[TITLEFONTSIZE].length)
		tt_aV[TITLEFONTSIZE] = tt_aV[FONTSIZE];
	if(tt_aV[CLOSEBTN])
	{
		// Use title colors for non-specified closebutton colors
		if(!tt_aV[CLOSEBTNCOLORS])
			tt_aV[CLOSEBTNCOLORS] = new Array("", "", "", "");
		for(var i = 4; i;)
		{--i;
			if(!tt_aV[CLOSEBTNCOLORS][i].length)
				tt_aV[CLOSEBTNCOLORS][i] = (i & 1) ? tt_aV[TITLEFONTCOLOR] : tt_aV[TITLEBGCOLOR];
		}
		// Enforce titlebar be shown
		if(!tt_aV[TITLE].length)
			tt_aV[TITLE] = " ";
	}
	// Circumvents broken display of images and fade-in flicker in Geckos < 1.8
	if(tt_aV[OPACITY] == 100 && typeof tt_aElt[0].style.MozOpacity != tt_u && !Array.every)
		tt_aV[OPACITY] = 99;
	// Smartly shorten the delay for fade-in tooltips
	if(tt_aV[FADEIN] && tt_flagOpa && tt_aV[DELAY] > 100)
		tt_aV[DELAY] = Math.max(tt_aV[DELAY] - tt_aV[FADEIN], 100);
}
function tt_AdaptConfig2()
{
	if(tt_aV[CENTERMOUSE])
		tt_aV[OFFSETX] -= ((tt_w - (tt_aV[SHADOW] ? tt_aV[SHADOWWIDTH] : 0)) >> 1);
}
// Expose content globally so extensions can modify it
function tt_MkTipContent(a)
{
	if(tt_t2t)
	{
		if(tt_aV[COPYCONTENT])
			tt_sContent = tt_t2t.innerHTML;
		else
			tt_sContent = "";
	}
	else
		tt_sContent = a[0];
	tt_ExtCallFncs(0, "CreateContentString");
}
function tt_MkTipSubDivs()
{
	var sCss = 'position:relative;margin:0px;padding:0px;border-width:0px;left:0px;top:0px;line-height:normal;width:auto;',
	sTbTrTd = ' cellspacing=0 cellpadding=0 border=0 style="' + sCss + '"><tbody style="' + sCss + '"><tr><td ';

	tt_aElt[0].innerHTML =
		(''
		+ (tt_aV[TITLE].length ?
			('<div id="WzTiTl" style="position:relative;z-index:1;">'
			+ '<table id="WzTiTlTb"' + sTbTrTd + 'id="WzTiTlI" style="' + sCss + '">'
			+ tt_aV[TITLE]
			+ '</td>'
			+ (tt_aV[CLOSEBTN] ?
				('<td align="right" style="' + sCss
				+ 'text-align:right;">'
				+ '<span id="WzClOsE" style="padding-left:2px;padding-right:2px;'
				+ 'cursor:' + (tt_ie ? 'hand' : 'pointer')
				+ ';" onmouseover="tt_OnCloseBtnOver(1)" onmouseout="tt_OnCloseBtnOver(0)" onclick="tt_HideInit()">'
				+ tt_aV[CLOSEBTNTEXT]
				+ '</span></td>')
				: '')
			+ '</tr></tbody></table></div>')
			: '')
		+ '<div id="WzBoDy" style="position:relative;z-index:0;">'
		+ '<table' + sTbTrTd + 'id="WzBoDyI" style="' + sCss + '">'
		+ tt_sContent
		+ '</td></tr></tbody></table></div>'
		+ (tt_aV[SHADOW]
			? ('<div id="WzTtShDwR" style="position:absolute;overflow:hidden;"></div>'
				+ '<div id="WzTtShDwB" style="position:relative;overflow:hidden;"></div>')
			: '')
		);
	tt_GetSubDivRefs();
	// Convert DOM node to tip
	if(tt_t2t && !tt_aV[COPYCONTENT])
	{
		// Store the tag's parent element so we can restore that DOM branch
		// once the tooltip is hidden
		tt_t2tDad = tt_t2t.parentNode || tt_t2t.parentElement || tt_t2t.offsetParent || null;
		if(tt_t2tDad)
		{
			tt_MovDomNode(tt_t2t, tt_t2tDad, tt_aElt[6]);
			tt_t2t.style.display = "block";
		}
	}
	tt_ExtCallFncs(0, "SubDivsCreated");
}
function tt_GetSubDivRefs()
{
	var aId = new Array("WzTiTl", "WzTiTlTb", "WzTiTlI", "WzClOsE", "WzBoDy", "WzBoDyI", "WzTtShDwB", "WzTtShDwR");

	for(var i = aId.length; i; --i)
		tt_aElt[i] = tt_GetElt(aId[i - 1]);
}
function tt_FormatTip()
{
	var css, w, iOffY, iOffSh;

	//--------- Title DIV ----------
	if(tt_aV[TITLE].length)
	{
		css = tt_aElt[1].style;
		css.background = tt_aV[TITLEBGCOLOR];
		css.paddingTop = (tt_aV[CLOSEBTN] ? 2 : 0) + "px";
		css.paddingBottom = "1px";
		css.paddingLeft = css.paddingRight = tt_aV[PADDING] + "px";
		css = tt_aElt[3].style;
		css.color = tt_aV[TITLEFONTCOLOR];
		css.fontFamily = tt_aV[TITLEFONTFACE];
		css.fontSize = tt_aV[TITLEFONTSIZE];
		css.fontWeight = "bold";
		css.textAlign = tt_aV[TITLEALIGN];
		// Close button DIV
		if(tt_aElt[4])
		{
			css.paddingRight = (tt_aV[PADDING] << 1) + "px";
			css = tt_aElt[4].style;
			css.background = tt_aV[CLOSEBTNCOLORS][0];
			css.color = tt_aV[CLOSEBTNCOLORS][1];
			css.fontFamily = tt_aV[TITLEFONTFACE];
			css.fontSize = tt_aV[TITLEFONTSIZE];
			css.fontWeight = "bold";
		}
		if(tt_aV[WIDTH] > 0)
			tt_w = tt_aV[WIDTH] + ((tt_aV[PADDING] + tt_aV[BORDERWIDTH]) << 1);
		else
		{
			tt_w = tt_GetDivW(tt_aElt[3]) + tt_GetDivW(tt_aElt[4]);
			// Some spacing between title DIV and closebutton
			if(tt_aElt[4])
				tt_w += tt_aV[PADDING];
		}
		// Ensure the top border of the body DIV be covered by the title DIV
		iOffY = -tt_aV[BORDERWIDTH];
	}
	else
	{
		tt_w = 0;
		iOffY = 0;
	}

	//-------- Body DIV ------------
	css = tt_aElt[5].style;
	css.top = iOffY + "px";
	if(tt_aV[BORDERWIDTH])
	{
		css.borderColor = tt_aV[BORDERCOLOR];
		css.borderStyle = tt_aV[BORDERSTYLE];
		css.borderWidth = tt_aV[BORDERWIDTH] + "px";
	}
	if(tt_aV[BGCOLOR].length)
		css.background = tt_aV[BGCOLOR];
	if(tt_aV[BGIMG].length)
		css.backgroundImage = "url(" + tt_aV[BGIMG] + ")";
	css.padding = tt_aV[PADDING] + "px";
	css.textAlign = tt_aV[TEXTALIGN];
	// TD inside body DIV
	css = tt_aElt[6].style;
	css.color = tt_aV[FONTCOLOR];
	css.fontFamily = tt_aV[FONTFACE];
	css.fontSize = tt_aV[FONTSIZE];
	css.fontWeight = tt_aV[FONTWEIGHT];
	css.background = "";
	css.textAlign = tt_aV[TEXTALIGN];
	if(tt_aV[WIDTH] > 0)
		w = tt_aV[WIDTH] + ((tt_aV[PADDING] + tt_aV[BORDERWIDTH]) << 1);
	else
		// We measure the width of the body's inner TD, because some browsers
		// expand the width of the container and outer body DIV to 100%
		w = tt_GetDivW(tt_aElt[6]) + ((tt_aV[PADDING] + tt_aV[BORDERWIDTH]) << 1);
	if(w > tt_w)
		tt_w = w;

	//--------- Shadow DIVs ------------
	if(tt_aV[SHADOW])
	{
		tt_w += tt_aV[SHADOWWIDTH];
		iOffSh = Math.floor((tt_aV[SHADOWWIDTH] * 4) / 3);
		// Bottom shadow
		css = tt_aElt[7].style;
		css.top = iOffY + "px";
		css.left = iOffSh + "px";
		css.width = (tt_w - iOffSh - tt_aV[SHADOWWIDTH]) + "px";
		css.height = tt_aV[SHADOWWIDTH] + "px";
		css.background = tt_aV[SHADOWCOLOR];
		// Right shadow
		css = tt_aElt[8].style;
		css.top = iOffSh + "px";
		css.left = (tt_w - tt_aV[SHADOWWIDTH]) + "px";
		css.width = tt_aV[SHADOWWIDTH] + "px";
		css.background = tt_aV[SHADOWCOLOR];
	}
	else
		iOffSh = 0;

	//-------- Container DIV -------
	tt_SetTipOpa(tt_aV[FADEIN] ? 0 : tt_aV[OPACITY]);
	tt_FixSize(iOffY, iOffSh);
}
// Fixate the size so it can't dynamically change while the tooltip is moving.
function tt_FixSize(iOffY, iOffSh)
{
	var wIn, wOut, i;

	tt_aElt[0].style.width = tt_w + "px";
	tt_aElt[0].style.pixelWidth = tt_w;
	wOut = tt_w - ((tt_aV[SHADOW]) ? tt_aV[SHADOWWIDTH] : 0);
	// Body
	wIn = wOut;
	if(!tt_bBoxOld)
		wIn -= ((tt_aV[PADDING] + tt_aV[BORDERWIDTH]) << 1);
	tt_aElt[5].style.width = wIn + "px";
	// Title
	if(tt_aElt[1])
	{
		wIn = wOut - (tt_aV[PADDING] << 1);
		if(!tt_bBoxOld)
			wOut = wIn;
		tt_aElt[1].style.width = wOut + "px";
		tt_aElt[2].style.width = wIn + "px";
	}
	tt_h = tt_GetDivH(tt_aElt[0]) + iOffY;
	// Right shadow
	if(tt_aElt[8])
		tt_aElt[8].style.height = (tt_h - iOffSh) + "px";
	i = tt_aElt.length - 1;
	if(tt_aElt[i])
	{
		tt_aElt[i].style.width = tt_w + "px";
		tt_aElt[i].style.height = tt_h + "px";
	}
}
function tt_DeAlt(el)
{
	var aKid;

	if(el.alt)
		el.alt = "";
	if(el.title)
		el.title = "";
	aKid = el.childNodes || el.children || null;
	if(aKid)
	{
		for(var i = aKid.length; i;)
			tt_DeAlt(aKid[--i]);
	}
}
// This hack removes the annoying native tooltips over links in Opera
function tt_OpDeHref(el)
{
	if(!tt_op)
		return;
	if(tt_elDeHref)
		tt_OpReHref();
	while(el)
	{
		if(el.hasAttribute("href"))
		{
			el.t_href = el.getAttribute("href");
			el.t_stats = window.status;
			el.removeAttribute("href");
			el.style.cursor = "hand";
			tt_AddEvtFnc(el, "mousedown", tt_OpReHref);
			window.status = el.t_href;
			tt_elDeHref = el;
			break;
		}
		el = el.parentElement;
	}
}
function tt_ShowInit()
{
	tt_tShow.Timer("tt_Show()", tt_aV[DELAY], true);
	if(tt_aV[CLICKCLOSE])
		tt_AddEvtFnc(document, "mouseup", tt_HideInit);
}
function tt_OverInit(e)
{
	tt_over = e.target || e.srcElement;
	tt_DeAlt(tt_over);
	tt_OpDeHref(tt_over);
	tt_AddRemOutFnc(true);
}
function tt_Show()
{
	var css = tt_aElt[0].style;

	// Override the z-index of the topmost wz_dragdrop.js D&D item
	css.zIndex = Math.max((window.dd && dd.z) ? (dd.z + 2) : 0, 1010);
	if(tt_aV[STICKY] || !tt_aV[FOLLOWMOUSE])
		tt_iState &= ~0x4;
	if(tt_aV[DURATION] > 0)
		tt_tDurt.Timer("tt_HideInit()", tt_aV[DURATION], true);
	tt_ExtCallFncs(0, "Show")
	css.visibility = "visible";
	tt_iState |= 0x2;
	if(tt_aV[FADEIN])
		tt_Fade(0, 0, tt_aV[OPACITY], Math.round(tt_aV[FADEIN] / tt_aV[FADEINTERVAL]));
	tt_ShowIfrm();
}
function tt_ShowIfrm()
{
	if(tt_ie56)
	{
		var ifrm = tt_aElt[tt_aElt.length - 1];
		if(ifrm)
		{
			var css = ifrm.style;
			css.zIndex = tt_aElt[0].style.zIndex - 1;
			css.display = "block";
		}
	}
}
function tt_Move(e)
{
	e = window.event || e;
	if(e)
	{
		tt_musX = tt_GetEvtX(e);
		tt_musY = tt_GetEvtY(e);
	}
	if(tt_iState)
	{
		if(!tt_over && e)
			tt_OverInit(e);
		if(tt_iState & 0x4)
		{
			// Protect some browsers against jam of mousemove events
			if(!tt_op && !tt_ie)
			{
				if(tt_bWait)
					return;
				tt_bWait = true;
				tt_tWaitMov.Timer("tt_bWait = false;", 1, true);
			}
			if(tt_aV[FIX])
			{
				tt_iState &= ~0x4;
				tt_SetTipPos(tt_aV[FIX][0], tt_aV[FIX][1]);
			}
			else if(!tt_ExtCallFncs(e, "MoveBefore"))
				tt_SetTipPos(tt_PosX(), tt_PosY());
			tt_ExtCallFncs([tt_musX, tt_musY], "MoveAfter")
		}
	}
}
function tt_PosX()
{
	var x;

	x = tt_musX;
	if(tt_aV[LEFT])
		x -= tt_w + tt_aV[OFFSETX] - (tt_aV[SHADOW] ? tt_aV[SHADOWWIDTH] : 0);
	else
		x += tt_aV[OFFSETX];
	// Prevent tip from extending past right/left clientarea boundary
	if(x > tt_maxPosX)
		x = tt_maxPosX;
	return((x < tt_scrlX) ? tt_scrlX : x);
}
function tt_PosY()
{
	var y;

	// Apply some hysteresis after the tip has snapped to the other side of the
	// mouse. In case of insufficient space above and below the mouse, we place
	// the tip below.
	if(tt_aV[ABOVE] && (!tt_bJmpVert || tt_CalcPosYAbove() >= tt_scrlY + 16))
		y = tt_DoPosYAbove();
	else if(!tt_aV[ABOVE] && tt_bJmpVert && tt_CalcPosYBelow() > tt_maxPosY - 16)
		y = tt_DoPosYAbove();
	else
		y = tt_DoPosYBelow();
	// Snap to other side of mouse if tip would extend past window boundary
	if(y > tt_maxPosY)
		y = tt_DoPosYAbove();
	if(y < tt_scrlY)
		y = tt_DoPosYBelow();
	return y;
}
function tt_DoPosYBelow()
{
	tt_bJmpVert = tt_aV[ABOVE];
	return tt_CalcPosYBelow();
}
function tt_DoPosYAbove()
{
	tt_bJmpVert = !tt_aV[ABOVE];
	return tt_CalcPosYAbove();
}
function tt_CalcPosYBelow()
{
	return(tt_musY + tt_aV[OFFSETY]);
}
function tt_CalcPosYAbove()
{
	var dy = tt_aV[OFFSETY] - (tt_aV[SHADOW] ? tt_aV[SHADOWWIDTH] : 0);
	if(tt_aV[OFFSETY] > 0 && dy <= 0)
		dy = 1;
	return(tt_musY - tt_h - dy);
}
function tt_OnOut()
{
	tt_AddRemOutFnc(false);
	if(!(tt_aV[STICKY] && (tt_iState & 0x2)))
		tt_HideInit();
}
function tt_HideInit()
{
	tt_ExtCallFncs(0, "HideInit");
	tt_iState &= ~0x4;
	if(tt_flagOpa && tt_aV[FADEOUT])
	{
		tt_tFade.EndTimer();
		if(tt_opa)
		{
			var n = Math.round(tt_aV[FADEOUT] / (tt_aV[FADEINTERVAL] * (tt_aV[OPACITY] / tt_opa)));
			tt_Fade(tt_opa, tt_opa, 0, n);
			return;
		}
	}
	tt_tHide.Timer("tt_Hide();", 1, false);
}
function tt_OpReHref()
{
	if(tt_elDeHref)
	{
		tt_elDeHref.setAttribute("href", tt_elDeHref.t_href);
		tt_RemEvtFnc(tt_elDeHref, "mousedown", tt_OpReHref);
		window.status = tt_elDeHref.t_stats;
		tt_elDeHref = null;
	}
}
function tt_Fade(a, now, z, n)
{
	if(n)
	{
		now += Math.round((z - now) / n);
		if((z > a) ? (now >= z) : (now <= z))
			now = z;
		else
			tt_tFade.Timer("tt_Fade("
							+ a + "," + now + "," + z + "," + (n - 1)
							+ ")",
							tt_aV[FADEINTERVAL],
							true);
	}
	now ? tt_SetTipOpa(now) : tt_Hide();
}
// To circumvent the opacity nesting flaws of IE, we set the opacity
// for each sub-DIV separately, rather than for the container DIV.
function tt_SetTipOpa(opa)
{
	tt_SetOpa(tt_aElt[5].style, opa);
	if(tt_aElt[1])
		tt_SetOpa(tt_aElt[1].style, opa);
	if(tt_aV[SHADOW])
	{
		opa = Math.round(opa * 0.8);
		tt_SetOpa(tt_aElt[7].style, opa);
		tt_SetOpa(tt_aElt[8].style, opa);
	}
}
function tt_OnCloseBtnOver(iOver)
{
	var css = tt_aElt[4].style;

	iOver <<= 1;
	css.background = tt_aV[CLOSEBTNCOLORS][iOver];
	css.color = tt_aV[CLOSEBTNCOLORS][iOver + 1];
}
function tt_Int(x)
{
	var y;

	return(isNaN(y = parseInt(x)) ? 0 : y);
}
// Adds or removes the document.mousemove or HoveredElem.mouseout handler
// conveniently. Keeps track of those handlers to prevent them from being
// set or removed redundantly.
function tt_AddRemOutFnc(bAdd)
{
	var PSet = bAdd ? tt_AddEvtFnc : tt_RemEvtFnc;

	if(bAdd != tt_AddRemOutFnc.bOn)
	{
		PSet(tt_over, "mouseout", tt_OnOut);
		tt_AddRemOutFnc.bOn = bAdd;
		if(!bAdd)
			tt_OpReHref();
	}
}
tt_AddRemOutFnc.bOn = false;
Number.prototype.Timer = function(s, iT, bUrge)
{
	if(!this.value || bUrge)
		this.value = window.setTimeout(s, iT);
}
Number.prototype.EndTimer = function()
{
	if(this.value)
	{
		window.clearTimeout(this.value);
		this.value = 0;
	}
}
function tt_SetOpa(css, opa)
{
	tt_opa = opa;
	if(tt_flagOpa == 1)
	{
		// Hack for bugs of IE:
		// A DIV cannot be made visible in a single step if an opacity < 100
		// has been applied while the DIV was hidden.
		// Moreover, in IE6, applying an opacity < 100 has no effect if the
		// concerned element has no layout (position, size, zoom, ...).
		if(opa < 100)
		{
			var bVis = css.visibility != "hidden";
			css.zoom = "100%";
			if(!bVis)
				css.visibility = "visible";
			css.filter = "alpha(opacity=" + opa + ")";
			if(!bVis)
				css.visibility = "hidden";
		}
		else
			css.filter = "";
	}
	else
	{
		opa /= 100.0;
		switch(tt_flagOpa)
		{
		case 2:
			css.KhtmlOpacity = opa; break;
		case 3:
			css.KHTMLOpacity = opa; break;
		case 4:
			css.MozOpacity = opa; break;
		case 5:
			css.opacity = opa; break;
		}
	}
}
function tt_MovDomNode(el, dadFrom, dadTo)
{
	if(dadFrom)
		dadFrom.removeChild(el);
	if(dadTo)
		dadTo.appendChild(el);
}
function tt_Err(sErr)
{
	if(tt_Debug)
		alert("Tooltip Script Error Message:\n\n" + sErr);
}

//===========  DEALING WITH EXTENSIONS	==============//
function tt_ExtCmdEnum()
{
	var s;

	// Add new command(s) to the commands enum
	for(var i in config)
	{
		s = "window." + i.toString().toUpperCase();
		if(eval("typeof(" + s + ") == tt_u"))
		{
			eval(s + " = " + tt_aV.length);
			tt_aV[tt_aV.length] = null;
		}
	}
}
function tt_ExtCallFncs(arg, sFnc)
{
	var b = false;
	for(var i = tt_aExt.length; i;)
	{--i;
		var fnc = tt_aExt[i]["On" + sFnc];
		// Call the method the extension has defined for this event
		if(fnc && fnc(arg))
			b = true;
	}
	return b;
}

tt_Init();
