Each app now carries everything under containers/<app>/: Tools-tab actions in tools/ (declaration <app>.tools.json + function <app>_<tool_id>.sh) and logic helpers in scripts/ (e.g. <app>_auth.sh). The container scan live-sources every .sh under the app (maxdepth 3, prunes only resources/) and webui_tools.sh auto-merges the .tools.json, so an app is a true drop-in — no central edit, no array regen. - Empty the central webui_tools.sh heredoc; all 34 tools across 11 apps now come from per-app declarations (verified byte-identical to the old output). - Retire the orphaned mattermost tool scripts to scripts/unused (there is no containers/mattermost; its install fn already lived in unused). - Update the dispatch comment/error path, the auth-adapter doc, and DEVELOPMENT.md to the new convention. - Regenerate static arrays (files_app.sh no longer lists app/containers/*). Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com> Signed-off-by: librelad <librelad@digitalangels.vip>
26 lines
868 B
Bash
26 lines
868 B
Bash
#!/bin/bash
|
|
|
|
# Tools-tab entry — invoked by `libreportal app tool dashy shortcuts_manage`.
|
|
# Resolved by dockerAppRunTool: tool id `shortcuts_manage` →
|
|
# function `appDashyManageShortcuts`.
|
|
#
|
|
# Modal field (see webui_tools.sh):
|
|
# selected — comma-separated app slugs the user wants on the dashboard.
|
|
#
|
|
# Persists the selection to CFG_DASHY_SHORTCUTS, then regenerates dashy's
|
|
# conf.yml via the existing appDashyUpdateConf and restarts the container.
|
|
appDashyManageShortcuts()
|
|
{
|
|
local tool_args="$1"
|
|
local selected
|
|
selected=$(toolArgsGet "$tool_args" "selected")
|
|
selected="${selected//%7C/|}"
|
|
|
|
local cfg_file="${containers_dir}dashy/dashy.config"
|
|
updateConfigOption "CFG_DASHY_SHORTCUTS" "$selected" "$cfg_file"
|
|
export CFG_DASHY_SHORTCUTS="$selected"
|
|
isSuccessful "Saved CFG_DASHY_SHORTCUTS=$selected"
|
|
|
|
appDashyUpdateConf
|
|
}
|