diff options
-rw-r--r-- | hm/soispha/pkgs/scripts.nix | 5 | ||||
-rwxr-xr-x | hm/soispha/pkgs/scripts/wrappers/neorg | 140 |
2 files changed, 115 insertions, 30 deletions
diff --git a/hm/soispha/pkgs/scripts.nix b/hm/soispha/pkgs/scripts.nix index 4124cf60..b65752a6 100644 --- a/hm/soispha/pkgs/scripts.nix +++ b/hm/soispha/pkgs/scripts.nix @@ -53,6 +53,11 @@ DEFAULT_NEORG_PROJECT_DIR = config.programs.nixvim.plugins.neorg.modules."core.dirman".config.workspaces.projects; HOME_TASKRC = "${config.xdg.configHome}/task/home-manager-taskrc"; + ALL_PROJECTS_NEWLINE = "${config.soispha.taskwarrior.projects.projects_newline}"; + ALL_PROJECTS_COMMA = "${config.soispha.taskwarrior.projects.projects_comma}"; + + # TODO: Replace the hard-coded path here with some reference <2023-10-20> + TASK_PROJECT_FILE = "/home/soispha/repos/nix/nixos-config/hm/soispha/conf/taskwarrior/projects/default.nix"; }; }; update-sys-scr = write_script { diff --git a/hm/soispha/pkgs/scripts/wrappers/neorg b/hm/soispha/pkgs/scripts/wrappers/neorg index c7e08c15..f26faac4 100755 --- a/hm/soispha/pkgs/scripts/wrappers/neorg +++ b/hm/soispha/pkgs/scripts/wrappers/neorg @@ -9,34 +9,49 @@ YEARS="2023" NAME="neorg" +set -ef + help() { cat << EOF This is a quick wrapper to make starting neorg easier. Usage: - $NAME [--help|--version] [<neorg workspace>] + $NAME [OPTIONS] [COMMAND] -Options: +OPTIONS: --help | -h Display this help and exit. --version | -v Display version and copyright information and exit. - --task ID | -t ID - Open the neorg project associated with the current context and - the uuid of the task with id ID. +COMMANDS: + task [ID] + Open the neorg context associated with the current context and + the uuid of the task with id ID. Without ID, it'll open the + current context's norg file. If no context is set, drops you to the selection prompt - <neorg workspace> - The neorg workspace to open at startup, an empty value drops + + workspace [WS] + The neorg workspace (WS) to open at startup, an empty value drops you at a prompt to enter the workspace yourself. - If unset (and no other options apply), opens the current task - context. + + project [P] + Opens the webbrowser with either the context (P) or + the current active context as argument if no context is supplied + + list + Lists all available contexts + + add + Allows you to quickly add projects + EOF } -get_current_context() { +# Utils {{{ +UTILS_get_current_context() { current_context="$(task _get rc.context)"; printf "%s\n" "$current_context"; } -get_current_context_path() { +UTILS_get_current_context_path() { current_context="$1"; context_path="$(task _get rc.context."$current_context".rc.neorg_path 2>/dev/null)"; if ! [ "$context_path" ]; then @@ -45,24 +60,28 @@ get_current_context_path() { fi printf "%s\n" "$context_path" } -get_neorg_project_dir() { +UTILS_get_neorg_project_dir() { # Perform shell expansion of Tilde neorg_project_dir="$(sed "s|~|$HOME|" "$(ptmp "%DEFAULT_NEORG_PROJECT_DIR")")"; printf "%s\n" "$neorg_project_dir" } +# }}} -open_neorg_workspace() { +# Workspace {{{ +WORKSPACE_open_neorg_workspace() { nvim -c "NeorgStart" -s "$(ptmp ":Neorg workspace $1\n")" } -open_neorg_workspace_prompt() { +WORKSPACE_open_neorg_workspace_prompt() { nvim -c "NeorgStart" -s "$(ptmp ":Neorg workspace ")" } -open_current_task_context() { - current_context="$(get_current_context)" +# }}} +# Context {{{ +CONTEXT_open_current_task_context() { + current_context="$(UTILS_get_current_context)" if [ "$current_context" ]; then - context_path="$(get_current_context_path "$current_context")"; + context_path="$(UTILS_get_current_context_path "$current_context")"; - extended_neorg_project_dir="$(get_neorg_project_dir)"; + extended_neorg_project_dir="$(UTILS_get_neorg_project_dir)"; cd "$extended_neorg_project_dir" || die "(BUG?): Can not access the project dir: $extended_neorg_project_dir"; nvim "$extended_neorg_project_dir/$context_path"; @@ -71,15 +90,15 @@ open_current_task_context() { git commit --message="chore($(dirname "$context_path")): Update" --no-gpg-sign else warn "No context active"; - open_neorg_workspace_prompt; + WORKSPACE_open_neorg_workspace_prompt; fi } -open_current_task_context_at_task_id() { +CONTEXT_open_current_task_context_at_task_id() { task_id="$1"; - current_context="$(get_current_context)" + current_context="$(UTILS_get_current_context)" if [ "$current_context" ]; then - context_path="$(get_current_context_path "$current_context")"; - extended_neorg_project_dir="$(get_neorg_project_dir)"; + context_path="$(UTILS_get_current_context_path "$current_context")"; + extended_neorg_project_dir="$(UTILS_get_neorg_project_dir)"; task_uuid="$(task "$task_id" uuids)" cd "$extended_neorg_project_dir" || die "(BUG?): Can not access the project dir: $extended_neorg_project_dir"; @@ -94,9 +113,45 @@ open_current_task_context_at_task_id() { git commit --message="chore($(dirname "$context_path")): Update" --no-gpg-sign else warn "No context active"; - open_neorg_workspace_prompt; + WORKSPACE_open_neorg_workspace_prompt; fi } +# }}} +# Project {{{ +PROJECT_open_current_context_in_browser() { + current_context="$(UTILS_get_current_context)"; + [ "$current_context" ] || WORKSPACE_open_neorg_workspace_prompt; + PROJECT_open_context_in_browser "$current_context"; +} +PROJECT_open_context_in_browser() { + context="$1"; + [ "$context" ] || die "BUG: No context supplied to PROJECT_open_context_in_browser" + + firefox -P "$context" +} +# }}} +# List {{{ +LIST_list_all_contexts_newline() { + print "%ALL_PROJECTS_NEWLINE" +} +LIST_list_all_contexts_comma() { + print "%ALL_PROJECTS_COMMA" +} +# }}} +# Add {{{ +ADD_open_taskwarrior_project_file() { + task_project_file="%TASK_PROJECT_FILE"; + cd "$task_project_file" || die "BUG: task_project_file ('$task_project_file') can't be accessed" + git_dir="$(search_flake_base_dir)"; + [ "$git_dir" ] || die "(BUG): No git directory?" + cd "$git_dir" || die "Unreachable, this MUST exists" + nvim "$task_project_file"; + git add "$task_project_file"; + + base_task_project_file_path="$(awk "{ gsub(\"$git_dir/\", \"\") }" "$(ptmp "$task_project_file")")" + git commit --verbose --message="chore($(dirname "$base_task_project_file_path")): Update" +} +# }}} for arg in "$@"; do case "$arg" in @@ -113,20 +168,45 @@ done while [ "$#" -ne 0 ]; do case "$1" in - "--task" | "-t") + "t"*) # task shift 1; task_id="$1"; - [ "$task_id" ] || die "You must have a task_id set! See --help for more" - open_current_task_context_at_task_id "$task_id"; + [ "$task_id" ] || CONTEXT_open_current_task_context; + CONTEXT_open_current_task_context_at_task_id "$task_id"; + exit 0; + ;; + "w"*) # workspace + shift 1; + workspace_to_open="$1"; + [ "$workspace_to_open" ] || WORKSPACE_open_neorg_workspace_prompt; + WORKSPACE_open_neorg_workspace "$workspace_to_open"; + exit 0; + ;; + "p"*) # project + shift 1; + context_to_open="$1"; + [ "$context_to_open" ] || PROJECT_open_current_context_in_browser; + if ! grep -q "$context_to_open" "$(ptmp "%ALL_PROJECTS_NEWLINE")"; then + die "Your context ('$context_to_open') is not in the list of available contexts: + %ALL_PROJECTS_COMMA"; + fi + PROJECT_open_context_in_browser "$context_to_open"; exit 0; ;; + "l"*) # list + LIST_list_all_contexts_newline; + exit 0 + ;; + "a"*) # add-project + ADD_open_taskwarrior_project_file; + exit 0 + ;; *) - open_neorg_workspace "$1"; + die "Command '$1' does not exist! Please look at:\n $NAME --help"; exit 0; ;; esac done -open_current_task_context; - +CONTEXT_open_current_task_context; # vim: ft=sh |