Před 30 lety, tj. v úterý 30. dubna 1996, byl spuštěn Seznam.cz.
Byly zpracovány a zveřejněny všechny videozáznamy, které stojí za zveřejnění, z konference FOSDEM 2026.
Od úterý 28. dubna musí nově uváděné notebooky v Evropské unii podporovat nabíjení přes USB-C. Jednotná nabíječka byla schválena Evropským parlamentem v říjnu 2022.
Byly publikovány informace o kritické zranitelnosti CVE-2026-31431 pojmenované Copy Fail v Linuxu, konkrétně v kryptografii (AF_ALG). Běžný uživatel může získat práva roota (lokální eskalaci práv). Na všech distribucích Linuxu vydaných od roku 2017. Pomocí 732bajtového skriptu. V upstreamu je již opraveno. Zranitelnost byla nalezena pomocí AI Xint Code.
Textový editor Zed dospěl do verze 1.0. Představení v příspěvku na blogu.
Vývojáři svobodného 3D softwaru Blender představili (𝕏, Mastodon, Bluesky) nejnovějšího firemního sponzora Blenderu. Je ním společnost Anthropic stojící za AI Claude a úroveň sponzoringu je Patron, tj. minimálně 240 tisíc eur ročně. Anthropic oznámil sponzorství v tiskové zprávě Claude for Creative Work.
VNC server wayvnc pro Wayland kompozitory postavené nad wlroots - ne GNOME, KDE nebo Weston - byl vydán ve verzi 0.10.0. Vydána byla také verze 1.0.0 související knihovny neatvnc.
Bylo oznámeno vydání Fedora Linuxu 44. Ve finální verzi vychází šest oficiálních edic: Fedora Workstation a Fedora KDE Plasma Desktop pro desktopové, Fedora Server pro serverové, Fedora IoT pro internet věcí, Fedora Cloud pro cloudové nasazení a Fedora CoreOS pro ty, kteří preferují neměnné systémy. Vedle nich jsou k dispozici také další atomické desktopy, spiny a laby. Podrobný přehled novinek v samostatných článcích na stránkách
… více »David Malcolm se na blogu vývojářů Red Hatu rozepsal o vybraných novinkách v GCC 16, jež by mělo vyjít v nejbližších dnech. Vypíchnuta jsou vylepšení čitelnosti chybových zpráv v C++, aktualizovaný SARIF (Static Analysis Results Interchange Format) výstup a nová volba experimental-html v HTML výstupu.
Byla vydána verze R14.1.6 desktopového prostředí Trinity Desktop Environment (TDE, fork KDE 3.5, Wikipedie). Přehled novinek v poznámkách k vydání, podrobnosti v seznamu změn.
Ajax GUI framework qooxdoo se dočkal verze 1.2. Ta přináší lepší podporu Selenium pro tvorbu automatických testů. Dále je novinkou virtual list, který pojme mnohem větší množství dat. Opraveno bylo na 200 bugů. Vývojáři se chlubí rozsáhlým manuálem čítajícím 400 stran. Ten je nově přístupný přes SVN. Více detailů v oficiálním oznámení.
Tiskni
Sdílej:
var simple = new Ext.form.FormPanel({
standardSubmit: true,
frame: true,
title: 'Register',
width: 350,
defaults: {
width: 230
},
defaultType: 'textfield',
items: [{
fieldLabel: 'Username',
name: 'username',
allowBlank: false
},
{
inputType: 'hidden',
id: 'submitbutton',
name: 'myhiddenbutton',
value: 'hiddenvalue'
}
],
buttons: [{
text: 'Submit',
handler: function () {
simple.getForm().getEl().dom.action = 'test.php';
simple.getForm().getEl().dom.method = 'POST';
simple.getForm().submit();
}
}]
});akoqx.Class.define("twitter.LoginWindow", {
extend: qx.ui.window.Window,
construct: function () {
this.base(arguments, "Login", "twitter/t_small-c.png");
}
});
var layout = new qx.ui.layout.Basic();
this.setLayout(layout);
this.setModal(true);
var form = new qx.ui.form.Form();
var username = new qx.ui.form.TextField();
username.setRequired(true);
form.add(username, "Username", null, "username");
var password = new qx.ui.form.PasswordField();
password.setRequired(true);
form.add(password, "Password", null, "password");
var controller = new qx.data.controller.Form(null, form);
var model = controller.createModel();
var loginbutton = new qx.ui.form.Button("Login");
form.addButton(loginbutton);
var cancelbutton = new qx.ui.form.Button("Cancel");
form.addButton(cancelbutton);
cancelbutton.addListener("execute", function () {
this.close();
}, this);Oba kódy robia formuláre, ale keďže sa mi nechce čítať dokumentácia k qooxdoo, tak vyzerajú a fungujú mierne inak, ale snáď sa na tom kóde dá vidieť, v čom je hlavný rozdiel. Hlavná výhoda (pre mňa) je to, že si nemusím pamätať poradie parametrov funkcií (a keďže to funguje práve takto, tak sa dá celá tá štruktúra poslať ako JSON zo serveru a jedným volaním funkcie sa potom vytvorí nové okno...).
qx.Class.define("ex.template.Editor",
{
extend: ex.data.form.DaoFormWindow,
construct: function(dao, data)
{
// Call superclass constructor.
this.base(arguments, dao, data);
},
members:
{
createForm: function()
{
this.createItems({
items: [
{ className: "ex.data.form.TextField" , id: "name" , autoLabel: true },
{ className: "ex.data.form.TextField" , id: "title" , autoLabel: true },
{ className: "ex.data.form.TextArea" , id: "content" , autoLabel: true, rowFlex: 1 }
]
});
this.createRules({
rules: [
{ className: "ex.data.form.Rule" , id: "name" , required: true }
]
});
},
applyPersistent: function(persistent)
{
this.setItemsEnabled(["name"], !persistent);
}
}
});
Já chápu qooxdoo jako low level toolkit, kde si člověk musí naprogramovat vlastní datovou a formulářovou vrstvu. To co tam je mi přijde jako hodně jednoduché. Na druhou stranu moje vrstva má asi 2000 řádků a řeší formuláře, jejich layout a data access.