Friendiiverse/App/Elems.js
2023-04-25 23:35:34 +02:00

58 lines
1.2 KiB
JavaScript

var ElsCfg = {
ListMenu: {
FullControl: {Append: true, Remove: true,},
},
};
function MkHtmlEl(Tag, Attrs) {
var El = document.createElement(Tag);
if (Attrs) {
Object.keys(Attrs).forEach(function(Attr){
El[Attr] = Attrs[Attr];
});
};
El.className += ` ${RndHtmlId(Tag)}`;
return El;
};
function MkWindow(Attrs) {
var Window = MkHtmlEl('div', Attrs);
Window.className += ' Window';
Root.appendChild(Window);
return Window;
};
function MkSelectMenu(Opts, Attrs) {
var Menu = MkHtmlEl('div', Attrs);
var OptsHtml = '';
Opts.forEach(function(Opt){
OptsHtml += '<li>' + MkHtmlEl('button', Opt).outerHTML + '</li>';
});
Menu.innerHTML = `
<button onclick="var El = this.nextElementSibling; El.hidden = !El.hidden;">
Select
</button>
<ul hidden="true">
${OptsHtml}
</ul>
`;
Menu.className += ' SelectMenu';
return Menu;
};
function MkListMenu(Opts, Conf, Attrs) {
var Menu = MkHtmlEl('div', Attrs);
var OptsHtml = '';
Object.keys(Opts).forEach(function(Opt){
OptsHtml += `<li><button>${Opt}</button><button>X</button></li>`;
});
Menu.innerHTML = `
<ul>
${Conf.Append ? '<li><button>Add New</button></li>' : ''}
${OptsHtml}
</ul>
`;
Menu.className += ' ListMenu';
return Menu;
};