Byla vydána nová verze 9.20 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání. Vypíchnout lze například nový balíček RustDesk Server pro vzdálený přístup.
Jonathan Thomas oznámil vydání nové verze 3.4.0 video editoru OpenShot (Wikipedie). Představení novinek také na YouTube. Zdrojové kódy OpenShotu jsou k dispozici na GitHubu. Ke stažení je i balíček ve formátu AppImage. Stačí jej stáhnout, nastavit právo na spouštění a spustit.
Byla vydána nová verze 1.6 otevřeného, licenčními poplatky nezatíženého, univerzálního ztrátového formátu komprese zvuku Opus (Wikipedie) a jeho referenční implementace libopus. Podrobnosti na demo stránce.
Vojtěch Polášek představil Vojtux, tj. linuxovou distribuci pro zrakově postižené uživatele. Vychází ze spinu Fedory 43 s desktopovým prostředím MATE. Konečným cílem je, aby žádný Vojtux nebyl potřeba a požadovaná vylepšení se dostala do upstreamu.
Byla vydána (Mastodon, 𝕏) druhá RC verze GIMPu 3.2. Přehled novinek v oznámení o vydání. Podrobně v souboru NEWS na GitLabu.
Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 160 (pdf).
Izrael od února zakáže dětem používat v prostorách základních škol mobilní telefony. Podle agentury AFP to uvedlo izraelské ministerstvo školství, které zdůraznilo negativní dopady, které na žactvo používání telefonů má. Izrael se tímto krokem přidává k rostoucímu počtu zemí, které dětem ve vzdělávacích zařízeních přístup k telefonům omezují.
Internetová společnost Google ze skupiny Alphabet pravděpodobně dostane příští rok pokutu od Evropské komise za nedostatečné dodržování pravidel proti upřednostňování vlastních služeb a produktů ve výsledcích vyhledávání. V březnu EK obvinila Google, že ve výsledcích vyhledávání upřednostňuje na úkor konkurence vlastní služby, například Google Shopping, Google Hotels a Google Flights. Případ staví Google proti specializovaným
… více »Byl oznámen program a spuštěna registrace na konferenci Prague PostgreSQL Developer Day 2026. Konference se koná 27. a 28. ledna a bude mít tři tracky s 18 přednáškami a jeden den workshopů.
Na webu československého síťařského setkání CSNOG 2026 je vyvěšený program, registrace a další informace k akci. CSNOG 2026 se uskuteční 21. a 22. ledna příštího roku a bude se i tentokrát konat ve Zlíně. Přednášky, kterých bude více než 30, budou opět rozdělené do tří bloků - správa sítí, legislativa a regulace a akademické projekty. Počet míst je omezený, proto kdo má zájem, měl by se registrovat co nejdříve.
Určitě jste už někdy potřebovali napsat kratší návod nebo krátký technický dokument. Technická dokumentace by měla mít na začátku obsah (TOC). Musíme tedy najít takový formát, který umí obsah (TOC) vygenerovat sám, protože udržovat dokument i s obsahem (TOC) je mírně řečeno nešikovné.
Popíšeme si tedy kousek Javascriptu, který umí vygenerovat a zobrazit klikací obsah v HTML. Někdy je totiž použití TeXu nevhodné (čtenář neocení krásné slitky fi, fl, ffi, ffl, vyrovnané mezery ve slově PLAVAT atd. Nehledě k tomu, že na Windows je GSView vzácnost. Stručně řečeno házíme perly sviním). Word nebo Swriter je je trošku jiná kategorie, hodně lidí s nimi nechce mít nic společného a navíc se moc nedá čekat, že příjemce uvidí dokument stejně jako my. (U HTML se to už vůbec nedá čekat, ale s tím se tak nějak počítá).
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
- <html>
- <head>
- <META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1">
- <META NAME="AUTHOR" CONTENT="Tomas Penicka">
- <!-- Based on http://www.quirksmode.org/dom/toc.html, but some changes were made-->
- <script type="text/javascript">
- function getElementsByTagNames(list,obj) {
- if (!obj) var obj = document;
- var tagNames = list.split(',');
- var resultArray = new Array();
- for (var i=0;i<tagNames.length;i++) {
- var tags = obj.getElementsByTagName(tagNames[i]);
- for (var j=0;j<tags.length;j++) {
- resultArray.push(tags[j]);
- }
- }
- var testNode = resultArray[0];
- if (!testNode) return [];
- if (testNode.sourceIndex) {
- resultArray.sort(function (a,b) {
- return a.sourceIndex - b.sourceIndex;
- });
- }
- else if (testNode.compareDocumentPosition) {
- resultArray.sort(function (a,b) {
- return 3 - (a.compareDocumentPosition(b) & 6);
- });
- }
- return resultArray;
- }
- function createTOC() {
- var y = document.createElement('div');
- y.id = 'innertoc';
- var a = y.appendChild(document.createElement('span'));
- a.onclick = showhideTOC;
- a.id = 'contentheader';
- a.innerHTML = 'hide page contents';
- var z = y.appendChild(document.createElement('div'));
- var toBeTOCced = getElementsByTagNames('h2,h3,h4,h5,h6');
- if (toBeTOCced.length < 2) return false;
- for (var i=0;i<toBeTOCced.length;i++) {
- var tmp = document.createElement('a');
- tmp.innerHTML = toBeTOCced[i].innerHTML;
- z.appendChild(tmp);
- tmp.className = 'indent' + toBeTOCced[i].nodeName.substring(1);
- var headerId = toBeTOCced[i].id || 'link' + i;
- tmp.href = '#' + headerId;
- toBeTOCced[i].id = headerId;
- }
- return y;
- }
- var TOCstate = 'block';
- function showhideTOC() {
- TOCstate = (TOCstate == 'none') ? 'block' : 'none';
- var newText = (TOCstate == 'none') ? 'show page contents' : 'hide page contents';
- document.getElementById('contentheader').innerHTML = newText;
- document.getElementById('contentheader').onclick = showhideTOC;
- document.getElementById('innertoc').lastChild.style.display = TOCstate;
- alert();
- }
- </script>
- <style type="text/css">
- #toc a {display: block; margin-top: 2pt; background-color: #EEEEEE;}
- #toc a:hover {background-color: #CCCCFF;}
- .indent2 {margin-left: 0em;}
- .indent3 {margin-left: 2em;}
- .indent4 {margin-left: 4em;}
- .indent5 {margin-left: 6em;}
- .indent6 {margin-left: 8em;}
- </style>
- <title></title>
- </head>
- <body onLoad="document.getElementById('toc').appendChild(createTOC());">
- <!-- The following DIV is exactly the place, where to TOC will be located, don't remove this -->
- <div id="toc"></div>
- </body>
- </html>
Chtěl jsem ještě přidat odkaz na příklad, ale zápisek už jsem uložil. (To byl vtip, ve skutečnosti jsem chtěl přidat k zápisku přílohu dostal jsem chybovou hlášku "přístup odmítnout")
Tiskni
Sdílej:

TeX samozřejmě používám raději, mám plno svých maker pro plain (LaTeX moc nemusím). Někdy je ale lepší sáhnout po tom, co umí i kolegové, aby mohli opravovat chyby apod.
a učinil blokovým elementem. Čisté řešení je použití zanořených seznamů a element a ponechat řádkovým.
Lze to napsat jako cyklus odhadem s 15–20 řádky kódu.