Dnes a zítra probíhá vývojářská konference Google I/O 2025. Sledovat lze na YouTube a na síti 𝕏 (#GoogleIO).
V Bostonu probíhá konference Red Hat Summit 2025. Vybrané přednášky lze sledovat na YouTube. Dění lze sledovat na síti 𝕏 (#RHSummit).
Společnost Red Hat oficiálně oznámila vydání Red Hat Enterprise Linuxu 10. Vedle nových vlastností přináší také aktualizaci ovladačů a předběžné ukázky budoucích technologií. Podrobnosti v poznámkách k vydání.
Tuto sobotu 24. května se koná historicky první komunitní den projektu Home Assistant. Zváni jsou všichni příznivci, nadšenci a uživatelé tohoto projektu. Pro účast je potřebná registrace. Odkazy na akce v Praze a v Bratislavě.
Troy Hunt představil Have I Been Pwned 2.0, tj. nový vylepšený web služby, kde si uživatelé mohou zkontrolovat, zda se jejich hesla a osobní údaje neobjevily v únicích dat a případně se nechat na další úniky upozorňovat.
Microsoft představil open source textový editor Edit bežící v terminálu. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.
V Seattlu a také online probíhá konference Microsoft Build 2025. Microsoft představuje své novinky. Windows Subsystem for Linux je nově open source. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.
Z příspěvku Turris Sentinel – co přinesl rok 2024 na blogu CZ.NIC: "Za poslední rok (únor 2024 – únor 2025) jsme zachytili 8,3 miliardy incidentů a to z 232 zemí a z jejich závislých území. Tyto útoky přišly od 6,2 milionu útočníků (respektive unikátních adres). SMTP minipot je stále nejlákavější pastí, zhruba 79 % útoků bylo směřováno na tento minipot, 16 % útoků směřovalo na minipot Telnet, 3 % útoků směřovaly na minipot HTTP a 2 % na minipot FTP. Dále jsme zaznamenali 3,2 milionu unikátních hesel a 318 tisíc unikátních loginů, které útočníci zkoušeli."
Byla vydána (Mastodon, 𝕏) nová verze 3.0.4 svobodné aplikace pro úpravu a vytváření rastrové grafiky GIMP (GNU Image Manipulation Program). Přehled novinek v oznámení o vydání a v souboru NEWS na GitLabu. Nový GIMP je již k dispozici také na Flathubu.
Byla vydána nová stabilní verze 7.4 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 136. Přehled novinek i s náhledy v příspěvku na blogu.
Když jsem byl loni konce léta na svatbě našich přátel, obrátil se tam na mne s dětskou důvěrou kamarádův jedenáctiletý syn – začal se zajímat o to jak se dělají webové stránky a tak chtěl vysvětlit jak to všechno funguje. S hrůzou jsem si uvědomil kolik jsem toho za ty roky zapoměl. Ovšem takové zapomínání není úplně na škodu, protože se tím zbavíte i zažitých postupů, které už jsou dávno obsolete. Každopádně mne tím přinutil abych se zase po nějakém čase podíval na věci kolem webu a javascriptu. A to jsem netušil, jak brzy se mi to bude hodit.
V prosinci jsem konečně dostal do použitelné podoby djvutool shellový tool pro práci s DjVu soubory, když moji pozornost upoutal DjVu.js Podle všeho v rámci tohoto repozitáře oprášil Nikolaj Suchanov svůj původní javascriptový kód pro čtení obrazové informace DjVu souborů z r. 2014 a přepsal ho do ECMA6.
Tím ovšem defakto vyřešil můj základní problém, který stál v mé cestě za dlouhodobým cílem – mít k dispozici multiplatformní nástroj pro práci s DjVu soubory. Javascriptový editor pro úpravy textové vrstvy DjVu souborů už totiž existuje – WebDjVuTextEd. Má však jednu zásadní vadu – je závislý na nástrojích DjVuLibre, stejně jako ten můj shellový skript.
Skloubením těchto dvou aplikací však lze vytvořit aplikaci zcela multiplatformní, použitelnou bez ohledu na OS. Pěkná myšlenka, není-liž pravda? Ti co se o věc zajímají vědí, že ani komerční nástroje pro práci s DjVu soubory (které už dávno nejsou k dispozici) nikdy neměly tak komfortní možnosti úpravy textové vrstvy. O metadatech ani nemluvě.
Vyhrabal jsem tedy z hloubi duše trosky a pustil se do studia kódu DjVu.js To pro mne znamenalo především se dokopat k podrobnějšímu seznámení s využitím javascriptových konzolí a debuggerů, co nabízejí moderní weboví prohlížeče. Tyjo, mít takový luxus na zkoumání kódu v oněch dřevních dobách, to by byla jiná káva. No nic.
Především jsem zjistil, že autor DjVu.js začal přepracovávat svůj původní, víceméně nezávislý kód způsobem, který se mi moc nelíbí. Chápu jeho pohnutky, ale nevidím nejmenší důvod, proč bych měl kvůli dvou tří víceméně statických knihoven stahovat dalších 250MB dat. Následující text tedy nebude o mém zápolení s javascriptem, ale o tom jak se tomu vyhnout.
Původní kód DjVu.js pracoval s knihovnou jQuery (v2.1.1). Současná verze používala verzi novější, ale autor se rozhodl místo ní použít React.js
Nic proti, React.js je rozhodně správná volba, ale přiznám se, že jsem tím nadšen nebyl, protože tím pádem přestaly fungovat starší části jeho kódu, které řešily věci, které jsem potřeboval. A s postupem spojeným s instalací npm jsem k rozumnému výsledku nedošel. Problém totiž spočíval v tom, že svůj DjVu prohlížeč dělá primárně k webovému nasazení, kdežto mým záměrem je aby aplikace fungovala i bez toho že by byla závislá na webovém připojení.
Vrátil jsem se tedy nejprve ke starší verzi jeho kódu, kde byla k dispozici knihovna jquery-3.2.1.min.js abych mohl zjistit na čem kód DjVu.js havaruje. Což se mi podařilo. A když už jsem byl v tom, dopsal jsem si i věci, které mu chybí - především jde o třídy pro zpracování skryté textové vrstvy a metadat.
Pak přišel na řadu druhý krok. Klíčovou výhodou pro nasazení React.js je skutečnost, že umožňuje dynamicky přegenerovat dílčí nody DOM modelu stránky přímo javascriptem, aniž by při tom bylo nutné pokaždé znovu načítat celý DOM objekt. U původní stránky to bylo řešeno tak, že se měnilo javascriptem nastavení atributu viditelnosti u div elementů.
Ovšem jak to udělat, aniž by bylo nutné instalovat to zpropadené Node.js?
Odpověď na mou otázku mi dal blogpost, který před dvěma lety napsal Shing Lyu. Až dodatečně jsem pak zjistil, že ani ne před měsícem publikoval jeho aktualizovanou verzi. Nechci tady uvádět tupý překlad jeho blogpostu, takže se omezím pouze na detail.
Shing Lyu ve svém blogpostu uvádí, jak přilinkovat potřebné knihovny tak, aby nebylo nutné používat npm. Já osobně jsem si raději potřebné knihovny stáhnul rovnou do prepozitáře, abych nebyl závislý na připojení, když chci na kódu pracovat offline. Navíc zkušenost s aplikací WebDjVuTextEd mě poučila, že je lepší mít všechny potřebné kódy pohromadě, než spoléhat na to, že budou ke stažení z původní lokace navždy.
Stáhnul jsem si tedy jak verze development, se kterými se lépe pracuje při trasování kódu, tak verze komprimované – pro budoucí finální použití.
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>Test</title> <script type="text/javascript" src="app/react.development.js"></script> <script type="text/javascript" src="app/react-dom.development.js"></script> <script type="text/javascript" src="app/babel.js"></script> </head> <body> <div id='root'> <script type="text/babel"> function tick() { const element = ( <div> <h1>Hello, world!</h1> <h2>It is {new Date().toLocaleTimeString()}.</h2> </div> ); ReactDOM.render(element, document.getElementById('root')); } setInterval(tick, 1000); </script> </div> </body> </html>Upozorňuji na zvýrazněnou část kódu - bez ní JSX syntaxe (kterou zpracovává babel.js) fungovat nebude.
Tiskni
Sdílej: