nix/modules/papis.nix
Yan Lin ebfb6f3bf2 Fix BibTeX template type field to use correct syntax
- Remove unnecessary double brace escaping from type field
- Use @{doc[type]} directly as papis handles it correctly

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-07-31 12:50:14 +02:00

153 lines
4.3 KiB
Nix

{ pkgs, ... }:
{
# Papis configuration
home.file."Library/Application Support/papis/config".text = ''
[settings]
default-library = main
editor = nvim
opentool = open
file-browser = open
# Document management
ref-format = {doc[author]}{doc[year]}
# Search and display
sort-field = year
sort-reverse = True
match-format = {doc[tags]}{doc[author]}{doc[title]}{doc[year]}
# Database and storage
database-backend = papis
use-git = False
# Interface
fzf-binary = fzf
picktool = fzf
[main]
dir = ~/Documents/Library/papis
# Local configuration for the main library
local-config-file = .papisrc
'';
# Create the papis library directory
home.activation.createPapisDir = ''
mkdir -p ~/Documents/Library/papis
'';
# Papis bibliography template
home.file."Library/Application Support/papis/templates/bibitem.template".text = ''
{doc[title]} ({doc[year]}). {doc[author]}.
Venue: {doc[journal]} {doc[booktitle]} {doc[eprinttype]} {doc[eprint]} {doc[eventtitle]}
Tags: {doc[tags]}
URL: {doc[url]}
---
'';
# Papis BibTeX template
home.file."Library/Application Support/papis/templates/bibtex.template".text = ''
@{doc[type]}{{{doc[ref]},
author = {{{doc[author]}}},
title = {{{doc[title]}}},
year = {{{doc[year]}}},
journal = {{{doc[journal]}}},
booktitle = {{{doc[booktitle]}}},
volume = {{{doc[volume]}}},
number = {{{doc[number]}}},
pages = {{{doc[pages]}}},
doi = {{{doc[doi]}}},
url = {{{doc[url]}}}
}}
'';
# Shell aliases for papis workflow
programs.zsh.shellAliases = {
# Bibliography formatting
pals = "papis list --template \"$HOME/Library/Application Support/papis/templates/bibitem.template\"";
# BibTeX export
pabib = "papis list --template \"$HOME/Library/Application Support/papis/templates/bibtex.template\"";
# File operations
paurl = "papis addto -u";
# Open documents
paopen = "papis open";
# Cache management
pareset = "papis cache reset";
};
# Shell functions for papis workflow
programs.zsh.initContent = ''
# Papis finder function - open document directory in Finder with query support
pafinder() {
local result=$(papis list "$@" | head -1)
if [ -n "$result" ]; then
open -R "$result"
else
echo "No documents found"
return 1
fi
}
# Papis add file function - add file to existing document with proper parameter handling
pafile() {
if [ $# -lt 1 ]; then
echo "Usage: pafile <filename> [query]"
echo "Example: pafile paper.pdf # Interactive selection"
echo "Example: pafile paper.pdf \"einstein relativity\" # Direct match"
echo "Example: pafile /path/to/paper.pdf \"quantum\" # Absolute path"
return 1
fi
local filename="$1"
shift # Remove first argument
local query="$*" # All remaining arguments as query (empty if none)
# Check if filename is absolute path or relative to Downloads
if [[ "$filename" == /* ]]; then
# Absolute path
if [ -n "$query" ]; then
papis addto -f "$filename" "$query"
else
papis addto -f "$filename"
fi
else
# Relative to Downloads
if [ -n "$query" ]; then
papis addto -f "$HOME/Downloads/$filename" "$query"
else
papis addto -f "$HOME/Downloads/$filename"
fi
fi
}
# Papis tag function - rewrite tags using hash-separated format
patag() {
if [ $# -ne 2 ]; then
echo "Usage: patag \"tag1#tag2#tag3\" <query>"
echo "Example: patag \"materials#ai4science\" amorphous"
echo "Example: patag \"quantum#computing\" \"author:einstein\""
return 1
fi
local tags_string="$1"
local query="$2"
# First, drop all existing tags
papis tag --drop "$query"
# Add each tag individually by splitting on #
echo "$tags_string" | tr '#' '\n' | while read tag; do
# Trim whitespace
tag=$(echo "$tag" | xargs)
if [ -n "$tag" ]; then
papis tag --add "$tag" "$query"
fi
done
}
'';
}