about summary refs log tree commit diff stats
path: root/hm/soispha/pkgs/scripts
diff options
context:
space:
mode:
authorSoispha <soispha@vhack.eu>2023-10-19 10:10:52 +0200
committerSoispha <soispha@vhack.eu>2023-10-19 10:10:52 +0200
commite2d84ece390a531940b9b6484711d9899a8d074a (patch)
tree161e4cc310b719688f98646c53e2dfb66484932a /hm/soispha/pkgs/scripts
parentfeat(hm/conf/taskwarrior): Automatically save the task data in a git repo (diff)
downloadnixos-config-e2d84ece390a531940b9b6484711d9899a8d074a.zip
feat(hm/pkgs/scr/neorg): Support task specific heads in norg files
Diffstat (limited to '')
-rwxr-xr-xhm/soispha/pkgs/scripts/wrappers/neorg80
1 files changed, 63 insertions, 17 deletions
diff --git a/hm/soispha/pkgs/scripts/wrappers/neorg b/hm/soispha/pkgs/scripts/wrappers/neorg
index 2bdb82cf..ce45cc44 100755
--- a/hm/soispha/pkgs/scripts/wrappers/neorg
+++ b/hm/soispha/pkgs/scripts/wrappers/neorg
@@ -14,21 +14,42 @@ cat << EOF
 This is a quick wrapper to make starting neorg easier.
 
 Usage:
-    $NAME [--help|--version] <neorg workspace>
+    $NAME [--help|--version] [<neorg workspace>]
 
 Options:
     --help      | -h
                             Display this help and exit.
     --version   | -v
                             Display version and copyright information and exit.
-    --task      | -t
-                            Open the neorg project associated with the current context.
-                            If no context is set, drop to the selection prompt
+    --task  ID  | -t ID
+                            Open the neorg project associated with the current context and
+                            the uuid of the task with id ID.
+                            If no context is set, drops you to the selection prompt
     <neorg workspace>
                             The neorg workspace to open at startup, an empty value drops
-                            you at a prompt to enter the workspace yourself
+                            you at a prompt to enter the workspace yourself.
+                            If unset (and no other options apply), opens the current task
+                            context.
 EOF
 }
+get_current_context() {
+    current_context="$(task _get rc.context)";
+    printf "%s\n" "$current_context";
+}
+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
+        context_path="$(grep "context.$current_context.rc.neorg_path" "%HOME_TASKRC" | awk 'BEGIN {FS="="} {print $2}')";
+        [ "$context_path" ] || die "All contexts should have a 'neorg_path' set!"
+    fi
+    printf "%s\n" "$context_path"
+}
+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() {
     nvim -c "NeorgStart" -s "$(ptmp ":Neorg workspace $1\n")"
@@ -37,19 +58,42 @@ open_neorg_workspace_prompt() {
     nvim -c "NeorgStart" -s "$(ptmp ":Neorg workspace ")"
 }
 open_current_task_context() {
-    current_context="$(task _get rc.context)";
+    current_context="$(get_current_context)"
     if [ "$current_context" ]; then
-        context_path="$(task _get rc.context."$current_context".rc.neorg_path 2>/dev/null)";
-        if ! [ "$context_path" ]; then
-            context_path="$(grep "context.$current_context.rc.neorg_path" "%HOME_TASKRC" | awk 'BEGIN {FS="="} {print $2}')";
-            [ "$context_path" ] || die "All contexts should have a 'neorg_path' set!"
+        context_path="$(get_current_context_path "$current_context")";
+
+        extended_neorg_project_dir="$(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";
+
+        git add .;
+        git commit --message="chore($(dirname "$context_path")): Update" --no-gpg-sign
+    else
+        warn "No context active";
+        open_neorg_workspace_prompt;
+    fi
+}
+open_current_task_context_at_task_id() {
+    task_id="$1";
+    current_context="$(get_current_context)"
+    if [ "$current_context" ]; then
+        context_path="$(get_current_context_path "$current_context")";
+        extended_neorg_project_dir="$(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";
+
+        if ! grep -q "% $task_uuid" "$extended_neorg_project_dir/$context_path"; then
+            echo "* TITLE (% $task_uuid)" >> "$extended_neorg_project_dir/$context_path"
         fi
 
-        # Perform shell expansion of Tilde
-        extended_neorg_project_dir="$(sed "s|~|$HOME|" "$(ptmp "%DEFAULT_NEORG_PROJECT_DIR")")";
-        (cd "$extended_neorg_project_dir" && nvim +edit "$extended_neorg_project_dir/$context_path";)
+        nvim "$extended_neorg_project_dir/$context_path" --cmd "/% $task_uuid";
+
+        git add .;
+        git commit --message="chore($(dirname "$context_path")): Update" --no-gpg-sign
     else
-        dbg "No context active";
+        warn "No context active";
         open_neorg_workspace_prompt;
     fi
 }
@@ -70,7 +114,10 @@ done
 while [ "$#" -ne 0 ]; do
     case "$1" in
         "--task" | "-t")
-            open_current_task_context;
+            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";
             exit 0;
             ;;
         *)
@@ -78,9 +125,8 @@ while [ "$#" -ne 0 ]; do
             exit 0;
             ;;
     esac
-    shift 1
 done
 
-open_neorg_workspace_prompt;
+open_current_task_context;
 
 # vim: ft=sh