frontend-dali/source/pages/overview/logic.ts

236 lines
5.7 KiB
TypeScript
Raw Normal View History

2025-09-25 17:54:20 +02:00
namespace _dali.pages.overview
2024-09-26 16:47:01 +02:00
{
/**
*/
lib_plankton.zoo_page.register(
"overview",
2024-09-26 16:47:01 +02:00
async (parameters, target_element) => {
// params
const view_mode : _dali.type.enum_view_mode = view_mode_determine(parameters["mode"] ?? "auto");
/**
* @todo ordentlich machen (nicht nur week und list)
*/
const set_view_mode = (view_mode) => {
const compact : boolean = (view_mode !== _dali.type.enum_view_mode.week);
target_element.querySelector("#overview").classList.toggle("overview-compact", compact);
};
// exec
2025-09-25 17:54:20 +02:00
target_element.innerHTML = await _dali.helpers.template_coin(
"overview",
"default",
2024-09-26 16:47:01 +02:00
{
}
);
// mode switcher
{
const widget_mode_switcher : _dali.class_widget = new _dali.widgets.mode_switcher.class_widget_mode_switcher(
[
{
"mode": _dali.type.enum_view_mode.week,
"label": lib_plankton.translate.get("page.overview.mode.week"),
},
{
"mode": _dali.type.enum_view_mode.list,
"label": lib_plankton.translate.get("page.overview.mode.list"),
},
],
{
"initial_selection": view_mode,
"action_change": (view_mode) => {
lib_plankton.zoo_page.set(
{
"name": "overview",
"parameters": {
"mode": _dali.view_mode_encode(view_mode),
}
}
);
set_view_mode(view_mode);
}
}
);
set_view_mode(view_mode);
await widget_mode_switcher.load(target_element.querySelector("#overview-mode"));
}
2025-09-25 17:54:20 +02:00
let widget_weekview : _dali.widgets.weekview.class_widget_weekview;
let widget_listview : _dali.widgets.listview.class_widget_listview;
2024-10-10 23:00:51 +02:00
// hint
{
if (! await _dali.backend.is_logged_in())
{
target_element.querySelector("#overview-hint").textContent = lib_plankton.translate.get("page.overview.login_hint");
2024-10-10 23:00:51 +02:00
}
else
{
2024-10-10 23:00:51 +02:00
// do nothing
}
}
// sources
{
const data : Array<
{
id : _dali.type.calendar_id;
name : string;
hue : float;
access_level : _dali.type.enum_access_level;
}
> = await _dali.backend.calendar_list(
);
const widget_sources = new _dali.widgets.sources.class_widget_sources(
data,
2024-09-30 20:20:14 +02:00
{
2024-10-21 23:18:08 +02:00
"action_open": (entry) => {
switch (entry.access_level)
{
case _dali.type.enum_access_level.none:
{
throw (new Error("this event should not be visible"));
break;
}
2025-09-25 17:54:20 +02:00
case _dali.type.enum_access_level.edit:
case _dali.type.enum_access_level.view:
{
lib_plankton.zoo_page.set(
{
"name": "calendar_edit",
"parameters": {
"read_only": "yes",
"calendar_id": entry.id,
}
}
);
break;
}
case _dali.type.enum_access_level.admin:
{
lib_plankton.zoo_page.set(
{
"name": "calendar_edit",
"parameters": {
"read_only": "no",
"calendar_id": entry.id,
}
}
);
break;
}
2024-09-30 20:20:14 +02:00
}
},
2024-10-21 23:18:08 +02:00
"action_toggle_visibility": (entry) => {
widget_weekview.toggle_visibility(entry.id);
widget_listview.toggle_visibility(entry.id);
2024-10-21 23:18:08 +02:00
},
2024-09-30 20:20:14 +02:00
}
);
await widget_sources.load(target_element.querySelector("#overview-pane-left"));
}
// events
{
2025-09-25 17:54:20 +02:00
const get_entries = (from_pit, to_pit, calendar_ids) => _dali.backend.events(
from_pit,
to_pit,
2024-09-30 20:20:14 +02:00
{
"calendar_ids": calendar_ids,
}
);
const action_select_event = (calendar_id, access_level, event_id) => {
switch (access_level)
{
case _dali.type.enum_access_level.none:
{
throw (new Error("this event should not be visible"));
break;
}
case _dali.type.enum_access_level.view:
{
lib_plankton.zoo_page.set(
{
"name": "event_edit",
"parameters": {
"read_only": "yes",
"calendar_id": calendar_id,
"event_id": event_id,
}
}
);
break;
}
2025-09-25 17:54:20 +02:00
case _dali.type.enum_access_level.edit:
case _dali.type.enum_access_level.admin:
{
lib_plankton.zoo_page.set(
{
"name": "event_edit",
"parameters": {
"read_only": "no",
"calendar_id": calendar_id,
"event_id": event_id,
}
}
);
break;
}
}
};
// listview
{
2024-10-21 23:18:08 +02:00
widget_listview = (
2025-09-25 17:54:20 +02:00
new _dali.widgets.listview.class_widget_listview(
get_entries,
{
"action_select_event": action_select_event,
"action_add": () => {
lib_plankton.zoo_page.set(
{
"name": "event_add",
"parameters": {
"calendar_id": null,
"year": null,
"month": null,
"day": null,
2024-09-30 20:20:14 +02:00
}
}
);
},
}
)
);
2024-10-21 23:18:08 +02:00
await widget_listview.load(target_element.querySelector("#overview-pane-right-listview"));
}
// weekview
{
2024-10-21 23:18:08 +02:00
widget_weekview = (
2025-09-25 17:54:20 +02:00
new _dali.widgets.weekview.class_widget_weekview(
get_entries,
{
"action_select_event": action_select_event,
"action_select_day": (date) => {
lib_plankton.zoo_page.set(
{
"name": "event_add",
"parameters": {
"calendar_id": null,
"year": date.year,
"month": date.month,
"day": date.day,
2024-09-30 20:20:14 +02:00
}
}
);
},
2024-09-30 20:20:14 +02:00
}
)
);
2024-10-21 23:18:08 +02:00
await widget_weekview.load(target_element.querySelector("#overview-pane-right-weekview"));
}
}
2024-09-26 16:47:01 +02:00
return Promise.resolve<void>(undefined);
},
);
}