Rev 300 Rev 311
1 // History: 1 // History:
2 // Oprava parametrů obrázku v hlavičce, oprava odkazu na stránku údržby 2 // Oprava parametrů obrázku v hlavičce, oprava odkazu na stránku údržby
3 // Doplněna detekce jazyka dokumentu (ve značce body) 3 // Doplněna detekce jazyka dokumentu (ve značce body)
4 // Předěláno na jinou strukturu adresářů, doplněno poukování odkazů 4 // Předěláno na jinou strukturu adresářů, doplněno poukování odkazů
5 // Oprava regulárního výrazu tak, aby nekazil odkaz Nahoru v patičce 5 // Oprava regulárního výrazu tak, aby nekazil odkaz Nahoru v patičce
6 // Změna kódování na UTF-8 6 // Změna kódování na UTF-8
-   7 // Doplněno automatické generování obsahu
7   8  
8 var RelPath=""; // Proměnná pro uložení relativní cesty k rootu webu 9 var RelPath=""; // Proměnná pro uložení relativní cesty k rootu webu
9 // Všechny cesty v tomto skriptu pak mají být cestami od 10 // Všechny cesty v tomto skriptu pak mají být cestami od
10 // rootu webu (například Web/PIC/MLAB.ico) 11 // rootu webu (například Web/PIC/MLAB.ico)
11   12  
12 function Test() 13 function Test()
13 // Testovací funkce pro ladění 14 // Testovací funkce pro ladění
14 { 15 {
15 with (document) 16 with (document)
16 { 17 {
17 var Info; 18 var Info;
18 // Test 19 // Test
19 // Užitečné: document.URL (cesta a jméno souboru stránky) 20 // Užitečné: document.URL (cesta a jméno souboru stránky)
20 write('<p class="MenuText Small">'); 21 write('<p class="MenuText Small">');
21 write('document language '+DocLang()); 22 write('document language '+DocLang());
22 write('</p>'); 23 write('</p>');
23 write('<p class="MenuText Small">'); 24 write('<p class="MenuText Small">');
24 write('document language '+navigator.appVersion); 25 write('document language '+navigator.appVersion);
25 write('</p>'); 26 write('</p>');
26 write('<p class="MenuText Small">'); 27 write('<p class="MenuText Small">');
27 write('document language '+document.body.lang); 28 write('document language '+document.body.lang);
28 write('</p>'); 29 write('</p>');
29 write('<p class="MenuText Small">'); 30 write('<p class="MenuText Small">');
30 write('navigator language '+navigator.language); // FF ano, IE6 ne 31 write('navigator language '+navigator.language); // FF ano, IE6 ne
31 write('</p>'); 32 write('</p>');
32 } 33 }
33 } 34 }
34   35  
35   36  
36 function DocLang() 37 function DocLang()
37 // Vrací zkratku jazyka stránky ( cs en ) 38 // Vrací zkratku jazyka stránky ( cs en )
38 // Není-li v dokumentu uvedená vrací en 39 // Není-li v dokumentu uvedená vrací en
39 { 40 {
40 var s; 41 var s;
41 s=document.body.lang.toLowerCase(); 42 s=document.body.lang.toLowerCase();
42 if(s=="cs") return "cs"; // To by mě zajímalo proč je čeština cs a ne cz 43 if(s=="cs") return "cs"; // To by mě zajímalo proč je čeština cs a ne cz
43 if(s=="sk") return "cs"; // Pro slováky bude asi čeština vhodnější 44 if(s=="sk") return "cs"; // Pro slováky bude asi čeština vhodnější
44 return "en"; // Pro všechny ostatní dáme angličtinu 45 return "en"; // Pro všechny ostatní dáme angličtinu
45 } 46 }
46   47  
47   48  
48 function SetRelativePath(Path) 49 function SetRelativePath(Path)
49 // Nastaví relativní část cesty tak, abychom se dostali k rootu webu 50 // Nastaví relativní část cesty tak, abychom se dostali k rootu webu
50 // Například pro stránky v adresáři "Web" je tento parametr "../" 51 // Například pro stránky v adresáři "Web" je tento parametr "../"
51 { 52 {
52 // Zapamatuji si relativní cestu 53 // Zapamatuji si relativní cestu
53 RelPath=Path; 54 RelPath=Path;
54 // Případně doplním na konec lomítko 55 // Případně doplním na konec lomítko
55 if (RelPath.length!=0) 56 if (RelPath.length!=0)
56 if (RelPath.charAt(RelPath.length-1)!='/') 57 if (RelPath.charAt(RelPath.length-1)!='/')
57 RelPath+='/'; 58 RelPath+='/';
58 } 59 }
59   60  
60   61  
61 function PokeRelativePath(Content) 62 function PokeRelativePath(Content)
62 // Vezme řetězec a doplní v něm všechny odkazy o relativní část cesty 63 // Vezme řetězec a doplní v něm všechny odkazy o relativní část cesty
63 { 64 {
64 Content=(Content.replace(/(\s+href=[\"\'])([^#])/ig,'$1'+RelPath+'$2')); 65 Content=(Content.replace(/(\s+href=[\"\'])([^#])/ig,'$1'+RelPath+'$2'));
65 Content=(Content.replace(/(\s+src=[\"\'])([^#])/ig,'$1'+RelPath+'$2')); 66 Content=(Content.replace(/(\s+src=[\"\'])([^#])/ig,'$1'+RelPath+'$2'));
66 return Content; 67 return Content;
67 } 68 }
68   69  
69   70  
70 function DrawHeader(MoreInfo) 71 function DrawHeader(MoreInfo)
71 // Nepovinny parametr udava nadpis stranky 72 // Nepovinny parametr udava nadpis stranky
72 // Neni-li uveden bere se text ze znacky title dokumentu 73 // Neni-li uveden bere se text ze znacky title dokumentu
73 { 74 {
74 // Proměnná pro vznikající vkládaný obsah 75 // Proměnná pro vznikající vkládaný obsah
75 var Content=""; 76 var Content="";
76 // Default informace pokud je parametr nezadany 77 // Default informace pokud je parametr nezadany
77 if(MoreInfo==undefined) MoreInfo=document.title; 78 if(MoreInfo==undefined) MoreInfo=document.title;
78 // Vlozeni HTML kodu 79 // Vlozeni HTML kodu
79 Content+='<div class="InnerHeader"> '; 80 Content+='<div class="InnerHeader"> ';
80 if (DocLang()=="cs") 81 if (DocLang()=="cs")
81 { // český text 82 { // český text
82 Content+='<a href="index.cs.html" title="Domů"><span class="HeaderLogo">MLAB</span><img src="Web/PIC/MLAB_online.gif" alt="MLAB Logo"></a>'; 83 Content+='<a href="index.cs.html" title="Domů"><span class="HeaderLogo">MLAB</span><img src="Web/PIC/MLAB_online.gif" alt="MLAB Logo"></a>';
83 } 84 }
84 else 85 else
85 { // English text 86 { // English text
86 Content+='<a href="index.en.html" title="Home"><span class="HeaderLogo">MLAB</span><img src="Web/PIC/MLAB_online.gif" alt="MLAB Logo"></a>'; 87 Content+='<a href="index.en.html" title="Home"><span class="HeaderLogo">MLAB</span><img src="Web/PIC/MLAB_online.gif" alt="MLAB Logo"></a>';
87 } 88 }
88 Content+='<span class="HeaderText">'+MoreInfo+'</span>'; 89 Content+='<span class="HeaderText">'+MoreInfo+'</span>';
89 Content+='</div> '; 90 Content+='</div> ';
90 // Korekce cest v odkazech 91 // Korekce cest v odkazech
91 Content=PokeRelativePath(Content); 92 Content=PokeRelativePath(Content);
92 // Výstup sestaveného textu 93 // Výstup sestaveného textu
93 document.write(Content); 94 document.write(Content);
94 } 95 }
95   96  
96   97  
97 function DrawMenu(MoreInfo) 98 function DrawMenu(MoreInfo)
98 // Nepovinny parametr udava nazev menu 99 // Nepovinny parametr udava nazev menu
99 // Neni-li uveden dava se text Menu 100 // Neni-li uveden dava se text Menu
100 { 101 {
101 // Proměnná pro vznikající vkládaný obsah 102 // Proměnná pro vznikající vkládaný obsah
102 var Content=""; 103 var Content="";
103 // Default text 104 // Default text
104 if(MoreInfo==undefined) MoreInfo="Menu"; 105 if(MoreInfo==undefined) MoreInfo="Menu";
105 // Vlastni menu 106 // Vlastni menu
106 Content+='<div class="InnerMenu">'; 107 Content+='<div class="InnerMenu">';
107 Content+=' <div class="Navigation">'; 108 Content+=' <div class="Navigation">';
108 Content+=' <div class="MenuText">'; 109 Content+=' <div class="MenuText">';
109 Content+= MoreInfo; 110 Content+= MoreInfo;
110 Content+=' </div>'; 111 Content+=' </div>';
111 if (DocLang()=="cs") 112 if (DocLang()=="cs")
112 { // český text 113 { // český text
113 Content+='<ul>'; 114 Content+='<ul>';
114 Content+=' <li> <a href="index.cs.html" title="Domů">Home</a> </li>'; 115 Content+=' <li> <a href="index.cs.html" title="Domů">Home</a> </li>';
115 Content+=' <li> <a href="Web/Articles.cs.html" title="Články, informace">Články</a> </li>'; 116 Content+=' <li> <a href="Web/Articles.cs.html" title="Články, informace">Články</a> </li>';
116 Content+=' <li> <a href="Web/Modules.cs.html" title="Jednotlivé moduly MLAB">Moduly</a> </li>'; 117 Content+=' <li> <a href="Web/Modules.cs.html" title="Jednotlivé moduly MLAB">Moduly</a> </li>';
117 Content+=' <li> <a href="Web/Designs.cs.html" title="Samostatné konstrukce">Konstrukce</a> </li>'; 118 Content+=' <li> <a href="Web/Designs.cs.html" title="Samostatné konstrukce">Konstrukce</a> </li>';
118 Content+=' <li> <a href="Web/News.cs.html" title="Novinky">Novinky</a> </li>'; 119 Content+=' <li> <a href="Web/News.cs.html" title="Novinky">Novinky</a> </li>';
119 Content+=' <li> <a href="Web/Photos.cs.html" title="Galerie fotografií">Fotogalerie</a> </li>'; 120 Content+=' <li> <a href="Web/Photos.cs.html" title="Galerie fotografií">Fotogalerie</a> </li>';
120 Content+=' <li> <a href="Web/Downloads.cs.html" title="Ke stažení">Download</a> </li>'; 121 Content+=' <li> <a href="Web/Downloads.cs.html" title="Ke stažení">Download</a> </li>';
121 Content+=' <li> <a href= "http://test.mlab.cz/WebSVN/listing.php?repname=MLAB&amp;path=%2F&amp;sc=0&amp;langchoice=Česky" title="Webový přístup do databáze SVN">WebSVN</a> </li>'; 122 Content+=' <li> <a href= "http://test.mlab.cz/WebSVN/listing.php?repname=MLAB&amp;path=%2F&amp;sc=0&amp;langchoice=Česky" title="Webový přístup do databáze SVN">WebSVN</a> </li>';
122 Content+=' <li> <a href= "http://test.mlab.cz/Forum" title="Forum uživatelů a autorů">Forum</a> </li>'; 123 Content+=' <li> <a href= "http://test.mlab.cz/Forum" title="Forum uživatelů a autorů">Forum</a> </li>';
123 Content+=' <li> <a href="Web/Maintenance.cs.html" title="Stránka údržby webu">Údržba</a> </li>'; 124 Content+=' <li> <a href="Web/Maintenance.cs.html" title="Stránka údržby webu">Údržba</a> </li>';
124 Content+=' <li> <a href="Web/About.cs.html" title="O webu, stavebnici MLAB atd.">O projektu</a> </li>'; 125 Content+=' <li> <a href="Web/About.cs.html" title="O webu, stavebnici MLAB atd.">O projektu</a> </li>';
125 Content+='</ul>'; 126 Content+='</ul>';
126 } 127 }
127 else 128 else
128 { // English text 129 { // English text
129 Content+='<ul>'; 130 Content+='<ul>';
130 Content+=' <li> <a href="index.en.html" title="Home">Home</a> </li>'; 131 Content+=' <li> <a href="index.en.html" title="Home">Home</a> </li>';
131 Content+=' <li> <a href="Web/Articles.en.html" title="Articles and other Texts">Articles</a></i>'; 132 Content+=' <li> <a href="Web/Articles.en.html" title="Articles and other Texts">Articles</a></i>';
132 Content+=' <li> <a href="Web/Modules.en.html" title="Individual MLAB Modules">Modules</a> </li>'; 133 Content+=' <li> <a href="Web/Modules.en.html" title="Individual MLAB Modules">Modules</a> </li>';
133 Content+=' <li> <a href="Web/Designs.en.html" title="Independed Designs">Designs</a> </li>'; 134 Content+=' <li> <a href="Web/Designs.en.html" title="Independed Designs">Designs</a> </li>';
134 Content+=' <li> <a href="Web/News.en.html" title="News">News</a> </li>'; 135 Content+=' <li> <a href="Web/News.en.html" title="News">News</a> </li>';
135 Content+=' <li> <a href="Web/Photos.en.html" title="Photo Gallery">Photogallery</a> </li>'; 136 Content+=' <li> <a href="Web/Photos.en.html" title="Photo Gallery">Photogallery</a> </li>';
136 Content+=' <li> <a href="Web/Downloads.en.html" title="For download">Downloads</a> </li>'; 137 Content+=' <li> <a href="Web/Downloads.en.html" title="For download">Downloads</a> </li>';
137 Content+=' <li> <a href= "http://test.mlab.cz/WebSVN/listing.php?repname=MLAB&amp;path=%2F&amp;sc=0&amp;langchoice=English" title="Web interface to SVN database">WebSVN</a> </li>'; 138 Content+=' <li> <a href= "http://test.mlab.cz/WebSVN/listing.php?repname=MLAB&amp;path=%2F&amp;sc=0&amp;langchoice=English" title="Web interface to SVN database">WebSVN</a> </li>';
138 Content+=' <li> <a href= "http://test.mlab.cz/Forum" title="Forum MLAB">Forum</a> </li>'; 139 Content+=' <li> <a href= "http://test.mlab.cz/Forum" title="Forum MLAB">Forum</a> </li>';
139 Content+=' <li> <a href="Web/Maintenance.en.html" title="Maintenance page">Maintenance</a> </li>'; 140 Content+=' <li> <a href="Web/Maintenance.en.html" title="Maintenance page">Maintenance</a> </li>';
140 Content+=' <li> <a href="Web/About.en.html" title="About Project">About</a> </li>'; 141 Content+=' <li> <a href="Web/About.en.html" title="About Project">About</a> </li>';
141 Content+='</ul>'; 142 Content+='</ul>';
142 } 143 }
143 Content+=' </div>'; 144 Content+=' </div>';
144 Content+='</div> '; 145 Content+='</div> ';
145 // Korekce cest v odkazech 146 // Korekce cest v odkazech
146 Content=PokeRelativePath(Content); 147 Content=PokeRelativePath(Content);
147 // Výstup sestaveného textu 148 // Výstup sestaveného textu
148 document.write(Content); 149 document.write(Content);
149 } 150 }
150   151  
151   152  
152 function DrawFooter(MoreInfo) 153 function DrawFooter(MoreInfo)
153 // Nepovinny parametr pro text do paticky 154 // Nepovinny parametr pro text do paticky
154 { 155 {
155 // Proměnná pro vznikající vkládaný obsah 156 // Proměnná pro vznikající vkládaný obsah
156 var Content=""; 157 var Content="";
157 // Default text je prazdny 158 // Default text je prazdny
158 if(MoreInfo==undefined) MoreInfo=""; 159 if(MoreInfo==undefined) MoreInfo="";
159 // Vlozeni HTML kodu 160 // Vlozeni HTML kodu
160 Content+='<div class="InnerFooter">'; 161 Content+='<div class="InnerFooter">';
161 Content+='&nbsp;'; // ústupek IE6 (chyba výpočtu šířky při nenulovém paddingu ) 162 Content+='&nbsp;'; // ústupek IE6 (chyba výpočtu šířky při nenulovém paddingu )
162 if (DocLang()=="cs") 163 if (DocLang()=="cs")
163 { // český text 164 { // český text
164 Content+='<a href="#">Nahoru</a> &nbsp; '; 165 Content+='<a href="#">Nahoru</a> &nbsp; ';
165 Content+='<a href="Web/Copyright.cs.html">Copyright</a> &copy; '; 166 Content+='<a href="Web/Copyright.cs.html">Copyright</a> &copy; ';
166 Content+='<a href="Web/AboutAuthors.cs.html">Autoři MLAB</a> &nbsp; '; 167 Content+='<a href="Web/AboutAuthors.cs.html">Autoři MLAB</a> &nbsp; ';
167 } 168 }
168 else 169 else
169 { // English text 170 { // English text
170 Content+='<a href="#">Up</a> &nbsp; '; 171 Content+='<a href="#">Up</a> &nbsp; ';
171 Content+='<a href="Web/Copyright.en.html">Copyright</a> &copy; '; 172 Content+='<a href="Web/Copyright.en.html">Copyright</a> &copy; ';
172 Content+='<a href="Web/AboutAuthors.en.html">MLAB Authors</a> &nbsp; '; 173 Content+='<a href="Web/AboutAuthors.en.html">MLAB Authors</a> &nbsp; ';
173 } 174 }
174 Content+='['+document.lastModified+'] &nbsp;&nbsp;&nbsp;'; 175 Content+='['+document.lastModified+'] &nbsp;&nbsp;&nbsp;';
175 Content+=MoreInfo; 176 Content+=MoreInfo;
176 Content+='</div>'; 177 Content+='</div>';
177 // Korekce cest v odkazech 178 // Korekce cest v odkazech
178 Content=PokeRelativePath(Content); 179 Content=PokeRelativePath(Content);
179 // Výstup sestaveného textu 180 // Výstup sestaveného textu
180 document.write(Content); 181 document.write(Content);
181 } 182 }
-   183  
-   184  
-   185 //=============================================
-   186 // Automatické generování obsahu
-   187 //
-   188 // Ke každé značce s class="PutTocHere x" vygeneruje obsah
-   189 // s hloubkou x nadpisů (defaultně 2 úrovně)
-   190  
-   191  
-   192 function tocGetText(obj)
-   193 // Vrať řetězec s obsahem elementu
-   194 {
-   195 var str=""
-   196 for (var i=0;i < obj.childNodes.length;i++)
-   197 {
-   198 if (obj.childNodes[i].nodeType==1) // ELEMENT_NODE
-   199 str += tocGetText(obj.childNodes[i])
-   200 else if (obj.childNodes[i].nodeType==3) // TEXT_NODE
-   201 str += obj.childNodes[i].data
-   202 }
-   203 return str
-   204 }
-   205  
-   206 var tocGlobalContext=0 // pro unikátní kotvy ve značce <a>
-   207  
-   208 function tocHeaders(el,obj,depth)
-   209 // Proleze hierarchickou strukturu a najde vsechny nadpisy
-   210 // do zadané úrovně včetně.
-   211 {
-   212 var tagList = "H1;H2;H3;H4;H5;H6;H7;"
-   213 if (tagList.indexOf(obj.tagName+";")>=0) // je to nadpis
-   214 if (obj.tagName.charAt(1)<=depth) // úroveň nadpisu
-   215 {
-   216 // Vytvoř položku seznamu
-   217 var eLI = document.createElement("li") // položka seznamu
-   218 var eA = document.createElement("a") // uvnitř link
-   219 var eLIText = document.createTextNode(tocGetText(obj)) // uvnitř text
-   220 eLI.className="Toc" + obj.tagName // úroveň nadpisu do class
-   221 eA.href="#_Toc_"+tocGlobalContext // cíl odkazu
-   222 eA.appendChild(eLIText) // vlož text do odkazu
-   223 eLI.appendChild(eA) // vlož odkaz do položky seznamu
-   224 el.appendChild(eLI) // vlož položku seznamu do seznamu
-   225  
-   226 // Přidej k nadpisu kotvu (znackou <a>)
-   227 var anchor=document.createElement("a")
-   228 anchor.id="_Toc_"+tocGlobalContext++ // unikátní jména kotev
-   229 obj.appendChild(anchor) // přidej kotvu k nadpisu
-   230 }
-   231 for (var i=0;i < obj.childNodes.length;i++) // rekurze
-   232 if (obj.childNodes[i].nodeType==1)
-   233 tocHeaders(el,obj.childNodes[i],depth)
-   234 }
-   235  
-   236  
-   237 function tocPutToc(objToc)
-   238 // Rekurzivně projdi strom dokumentu a na všechna místa kam patří
-   239 // vlož seznam. Místo je ozačeno značkou s id="PutTocHere".
-   240 // Volitelně může být uveden parametr Class="x", kde x udává hloubku
-   241 // zpracovávaných nadpisů.
-   242 {
-   243 var cl=objToc.className.split(" ") // vezmi class a rozděl ho na slova
-   244 if (cl[0].toUpperCase()=="PutTocHere".toUpperCase())
-   245 {
-   246 var depth=2 // default hodnota hloubky
-   247 for (var i=1;i<cl.length;i++)
-   248 {
-   249 if (cl[i]!="") // preskoč prázdné položky (IE6)
-   250 {
-   251 depth=cl[i] // byla zadána i druhá hodnota
-   252 break
-   253 }
-   254 }
-   255  
-   256 var toc = document.createElement("ul") // Toc je nečíslovaný seznam
-   257 toc.className="Toc" // s Class="Toc"
-   258  
-   259 var objHx = document.getElementsByTagName("body")[0] // Odtud začínáme
-   260 tocHeaders(toc,objHx,depth) // projdi všechny nadpisy
-   261 objToc.appendChild(toc) // přidej Toc jako jeho dítě
-   262 }
-   263 // Rekurzivní procházení dětí
-   264 for (var i=0;i < objToc.childNodes.length;i++)
-   265 if (objToc.childNodes[i].nodeType==1) // ELEMENT_NODE
-   266 (tocPutToc(objToc.childNodes[i]))
-   267 }
-   268  
-   269  
-   270 function doLoad()
-   271 // Tato funkce se spustí při načtení celé stránky.
-   272 {
-   273 // Najdi všechna místa pro seznam
-   274 var objToc = document.getElementsByTagName("body")[0] // Odtud začínáme
-   275 tocPutToc(objToc)
-   276 }
-   277  
-   278  
-   279 // Zaregistruj výkonný skript po načtení celé stránky
-   280 window.onload = doLoad