Francouzská veřejná správa má v rámci vládní iniciativy LaSuite Numérique ('Digitální sada') v plánu od roku 2027 přestat používat Microsoft Teams a Zoom a přejít na videokonferenční platformu Visio, hostovanou na vlastním hardwaru. Konkrétně se jedná o instance iniciativou vyvíjeného open-source nástroje LaSuite Meet, jehož centrální komponentou je LiveKit. Visio nebude dostupné pro veřejnost, nicméně LaSuite Meet je k dispozici pod licencí MIT.
Eben Upton oznámil další zdražení počítačů Raspberry Pi: 2GB verze o 10 dolarů, 4GB verze o 15 dolarů, 8GB verze o 30 dolarů a 16GB verze o 60 dolarů. Kvůli růstu cen pamětí. Po dvou měsících od předchozího zdražení.
Shellbeats je terminálový hudební přehrávač pro Linux a macOS, který umožňuje vyhledávat a streamovat hudbu z YouTube, stahovat odtud skladby a spravovat lokální playlisty. Pro stahování dat z YouTube využívá yt-dlp, pro práci s audiostreamy mpv. Je napsán v jazyce C a distribuován pod licencí GPL-3.0, rezpozitář projektu je na GitHubu.
Byla vydána nová verze 26.1.30 svobodného multiplatformního video editoru Shotcut (Wikipedie) postaveného nad multimediálním frameworkem MLT. S podporou hardwarového dekódování videa. Shotcut je vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.
LibrePCB, tj. svobodný multiplatformní softwarový nástroj pro návrh desek plošných spojů (PCB), byl po deseti měsících od vydání verze 1.3 vydán ve verzi 2.0.0. Přehled novinek v příspěvku na blogu a v aktualizované dokumentaci. Zdrojové kódy LibrePCB jsou k dispozici na GitHubu pod licencí GPLv3.
Guido van Rossum, tvůrce programovacího jazyka Python, oslavil 70. narozeniny. Narodil se 31. ledna 1956 v nizozemském Haarlemu.
OpenClaw je open-source AI asistent pro vykonávaní různých úkolů, ovládaný uživatelem prostřednictvím běžných chatovacích aplikací jako jsou například WhatsApp, Telegram nebo Discord. Asistent podporuje jak různé cloudové modely, tak i lokální, nicméně doporučován je pouze proprietární model Claude Opus 4.5 od firmy Anthropic v placené variantě. GitHubová stránka projektu OpenClaw.
Projekt VideoLAN a multimediální přehrávač VLC (Wikipedie) dnes slaví 25 let. Vlastní, tenkrát ještě studentský projekt, začal již v roce 1996 na vysoké škole École Centrale Paris. V první únorový den roku 2001 ale škola oficiálně povolila přelicencování zdrojových kódů na GPL a tím pádem umožnila používání VLC mimo akademickou půdu.
Moltbook je sociální síť podobná Redditu, ovšem pouze pro agenty umělé inteligence - lidé se mohou účastnit pouze jako pozorovatelé. Agenti tam například rozebírají podivné chování lidí, hledají chyby své vlastní sociální sítě, případně spolu filozofují o existenciálních otázkách 🤖.
scx_horoscope je „vědecky pochybný, kosmicky vtipný“ plně funkční plánovač CPU založený na sched_ext. Počítá s polohami Slunce a planet, fázemi měsíce a znameními zvěrokruhu. Upozornil na něj PC Gamer.
Aktivovanie editora nad HTML dokumentom sprístupní JavaScriptu štyri
nové funkcie dokumentu: execCommand(), queryCommandEnabled(), queryCommandState(), queryCommandValue().
Najdôležitejšou z týchto funkcií je execCommand(), ktorá
formátuje text, vkladá do dokumentu obrázky a odkazy, vracia zmeny
dokumentu (undo/redo), atď. Funkcia execCommand() očakáva 3
parametre:
document.execCommand(command,
userInterface, value)
Argumenty funkcie execCommand():
document.execCommand('createlink', false,
'http://www.abclinuxu.cz');
V praxi vykonáva funkcia execCommand() celú prácu
za nás a nemusíme sa starať o nič iné, ako volanie tejto funkcie
so správnymi argumentami. Rozšírme teda primitívny editor z minulej časti
o niekoľko formátovacích funkcií:
<html>
<head>
<title>Moj druhy WYSIWYG editor</title>
<script type="text/javascript">
var editor;
function setup() {
editor = document.getElementById('editor');
editor.contentWindow.document.designMode='on';
}
function editor_alert() {
alert(editor.contentWindow.document.body.innerHTML);
}
function editor_execCommand(command, value) {
editor.contentWindow.document.execCommand(command, false, value);
}
</script>
</head>
<body onload="setup();">
<p>Tento text nie je editovatelny... editujte obsah v ramci, prosim.</p>
<iframe id="editor" src="template.html"></iframe>
<p>Nastrojovy panel:</p>
<ul>
<li><a href="javascript: editor_alert();">
Ukaz mi to HTML!</a></li>
<li><a href="javascript: editor_execCommand('undo');">
Undo</a></li>
<li><a href="javascript: editor_execCommand('redo');">
Redo</a></li>
<li><a href="javascript: editor_execCommand('bold');">
Tucne</a></li>
<li><a href="javascript: editor_execCommand('italic');">
Kurziva</a></li>
<li><a href="javascript: editor_execCommand('underline');">
Podskrtnute</a></li>
<li><a href="javascript: editor_execCommand('strikethrough');">
Preskrtnute</a></li>
<li><a href="javascript: editor_execCommand('removeformat');">
Normalne</a></li>
<li><a href="javascript: editor_execCommand('formatblock', '<h1>');">
Nadpis 1</a></li>
<li><a href="javascript: editor_execCommand('formatblock', '<h2>');">
Nadpis 2</a></li>
<li><a href="javascript: editor_execCommand('formatblock', '<h3>');">
Nadpis 3</a></li>
<li><a href="javascript: editor_execCommand('formatblock', '<p>');">
Odstavec</a></li>
</ul>
</body>
</html>
Pridali sme do hlavného dokumentu ďalšiu JavaScriptovú funkciu
editor_execCommand(). Očakáva 2 argumenty, ale pri volaní
tejto funkcie si môžeme dovoliť druhý argument vynechať. V JavaScripte to
nie je chyba, v tele funkcie bude tento argument nastavený na hodnotu
undefined a táto hodnota je takmer to isté ako hodnota
null.
Funkcia editor_execCommand() jednoducho volá funkciu
execCommand() editovaného dokumentu a odovzdá mu svoje vlastné
dva argumenty. Pridávať môžeme aj ďalšie funkcie z nasledujúcej tabuľky:
| Operácia | Hodnota | Popis |
|---|---|---|
| undo | Vráti jednu zmenu v dokumente. | |
| redo | Znovu vykoná jednu vrátenú zmenu v dokumente. | |
| formatblock | <h1>, <h2>, ..., <p>, <pre>, ... | Uzavrie odstavec textu do zvoleného HTML tagu. |
| insertimage | adresa obrázku | Vloží na dokument obrázok. |
| removeformat | Odstráni všetky formátovacie HTML značky z označeného textu. | |
| createlink | adresa | Vytvorí z označeného textu hypertextový odkaz zo zvolenou adresou. |
| unlink | Zmení hypertextový odkaz na text. |
Kompletný zoznam príkazov podporovaných editorom Midas nájdete na v špecifikácii Midasu. Príkazy MSHTML Editoru sa nachádzajú v knižnici MSDN - Command Identifiers.
Odoslať HTML dokument po upravení na server môžeme viacerými spôsobmi.
Najjednoduchšie je dokument zakódovať do adresy dopytovanej webovej služby
ako argument. To znamená, že ak sme umiestnili webovú službu, ktorá dokument prijme a spracuje na adresu http://example.com/service a dokument vyzerá takto:
<h1>Ahoj svet!</h1><p>K&R napísali prvý
unix?</p>
tak pomocou JavaScriptu otvoríme v prehliadači adresu
http://example.com/service?text=%3Ch1%3EAhoj%20svet!%3C%2Fh1%3E%3Cp%3EK%
26R%20nap%C3%ADsali%20prv%C3%BDunix%3F%3C%2Fp%3E
function send_document(host) {
window.location.href = host + '?html='
+ encodeURIComponent(editor.contentWindow.document.body.innerHTML);
}
<li><a href="javascript: send_document('http://example.com/');">
Odoslat na example.com</a></li>
Nabudúce si prejdeme ďalšie možnosti odosielania dokumentu na server. Ďalej si ukážeme trik, ktorým uložíme dokument z Firefoxu na disk. Nakoniec si povieme pár slov o ostatných prehliadačoch podporujúcich WYSIWYG editor.
Nástroje: Tisk bez diskuse
Tiskni
Sdílej:
Kde v špecifikácii XHTML 1.0 STRICT sa píše, že URL v atribúte href nesmie mať protokol "javascript:"? Odporúča sa to, aby stroje vedeli, že po kliknutí na odkaz sa vykoná nejaký kód (aj tak im je to na figu).
Môj anchor je odkaz na funkciu a je mi jedno, ako ju bude užívateľ spúšťať. Keby som použil atribúť onclick, musel by som vytvoriť aj CSS pre ten odkaz, aby každý pochopil, že na neho treba kliknúť.
A vôbec, aký súvis má stránka s editorom s kódom, ktorý generuje? Veď si to kludne doma prepíšte podľa seba. A tento tutoriál vám má pomocť pochopiť tento druh editorov, aby ste si mohli vytvoriť vlastný generátor čistého XHTML kódu.
Vidíte? teraz ste ma rozčúlil... a musim si zase prekompilovať jadro, aby som sa ukludnil!