/* Espe | Ein schlichtes Werkzeug zur Mitglieder-Verwaltung | Frontend Copyright (C) 2024 Christian Fraß This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ lib_plankton.zoo_page.register( "member_view", async (parameters, target_element) => { const id : int = parseInt(parameters["id"]); let dom_fragment : DocumentFragment = template_request("member_view"); dom_fragment.querySelector(".member_view-title").textContent = lib_plankton.translate.get("page.member_view.title"); /** * @todo cache */ const groups_as_array : Array<{id : int; name : string;}> = await _espe.backend.group_list(); const groups_as_map : Map = new Map(); for (const group_thingy of groups_as_array) { groups_as_map.set(group_thingy.id, {"name": group_thingy.name}); } const member_data = await _espe.backend.member_get(id); const form = new lib_plankton.zoo_form.class_form< { name : string; groups : Array; enabled : boolean; email_address : (null | string); password_set : boolean; }, { name : string; groups : Set; enabled : boolean; email_address : (null | string); password_set : boolean; } >( value => ({ "name": value.name, "groups": new Set(value.groups.map(group_id => group_id.toFixed(0))), "enabled": value.enabled, "email_address": value.email_address, "password_set": value.password_set, }), representation => ({ "name": representation.name, "groups": (() => { const array : Array = []; for (const group_id_encoded of representation.groups) { array.push(parseInt(group_id_encoded)); } return array; }) (), "enabled": representation.enabled, "email_address": representation.email_address, "password_set": representation.password_set, }), new lib_plankton.zoo_input.class_input_group( [ { "name": "name", "input": new lib_plankton.zoo_input.class_input_text({"read_only": true}), "label": lib_plankton.translate.get("domain.member.name.label"), }, { "name": "groups", /* "input": new lib_plankton.zoo_input.class_input_list( () => new lib_plankton.zoo_input.class_input_number() ), */ "input": new _espe.class_input_set( groups_as_array.map( group_thingy => group_thingy.id.toFixed(0) ), group_id_encoded => groups_as_map.get(parseInt(group_id_encoded)).name ), "label": lib_plankton.translate.get("domain.member.groups.label"), }, { "name": "enabled", "input": new lib_plankton.zoo_input.class_input_checkbox(), "label": lib_plankton.translate.get("domain.member.enabled.label"), }, { "name": "password_set", "input": new lib_plankton.zoo_input.class_input_checkbox({"read_only": true}), "label": lib_plankton.translate.get("domain.member.password_set.label"), }, { "name": "email_address", "input": new lib_plankton.zoo_input.class_input_text(), "label": lib_plankton.translate.get("domain.member.email_address.label"), }, ] ), ( [ { "label": lib_plankton.translate.get("page.member_view.form.action.save"), "procedure": async (get_value, get_representation) => { const value = await get_value(); await _espe.backend.member_modify( id, { "email_address": value.email_address, "groups": value.groups, "enabled": value.enabled, } ); }, }, ] /* .concat( member_data.registered ? [] : [ { "label": lib_plankton.translate.get("page.member_view.form.action.summon"), "procedure": async (get_value, get_representation) => { const url : string = await _espe.backend.member_summon( id, lib_plankton.zoo_page.encode( { "name": "member_register", "parameters": { "id": id, "verification": "{{verification}}", } } ) ); if (_espe.conf.get().settings.test_mode) { alert(lib_plankton.translate.get("page.member_view.misc.test_info", {"url": url})); } else { alert(lib_plankton.translate.get("page.member_view.misc.summoned")); } }, }, ] ) */ ) ); await form.setup(dom_fragment.querySelector(".member_view-form") as HTMLElement); await form.input_write( { "name": member_data.name, "groups": member_data.groups, "enabled": member_data.enabled, "email_address": member_data.email_address, "password_set": member_data.password_set, } ); target_element.appendChild(dom_fragment); }, );