The script performs the following tasks:
- Checks if a local cache file containing YouTube video titles and URLs exists.
- If the file does not exist, it fetches video titles and URLs using yt-dlp and saves them to the local cache file.
- Prompts the user whether to update the database (local cache file) using dmenu.
- If the user chooses to update the database, the script fetches the latest video titles and URLs and updates the cache file.
- Displays the video titles in dmenu for the user to select.
- Once a video is selected, the script plays the video using the mpv video player.
Detailed Explanation of Commands:
- CHANNEL_URL="https://www.youtube.com/c/CHANNEL_NAME/videos": Sets the YouTube channel URL to be fetched.
- DATA_FILE="$HOME/.cache/yt_channel_data.tsv": Sets the file path for storing the fetched video titles and URLs.
- [ ! -f "$DATA_FILE" ] && yt-dlp -j --flat-playlist --skip-download "$CHANNEL_URL" | jq -r '[.title, .id] | @tsv' > "$DATA_FILE": Checks if the cache file exists. If not, it uses yt-dlp to fetch the video titles and URLs in JSON format, then pipes the JSON to jq to extract the title and URL, formats them as tab-separated values (TSV), and saves the output to the cache file.
- [ "$(echo -e "No\nYes" | dmenu -i -l 2 -p "Update?")" == "Yes" ] && yt-dlp -j --flat-playlist --skip-download "$CHANNEL_URL" | jq -r '[.title, .id] | @tsv' > "$DATA_FILE": Asks the user if they want to update the database using dmenu. If the user selects "Yes", the script fetches the latest video titles and URLs and updates the cache file.
- video_info=$(cat "$DATA_FILE"): Reads the contents of the cache file and stores them in the video_info variable.
- selected_title=$(echo "$video_info" | cut -f1 | dmenu -i -l 20 -p "Video:"): Displays the video titles in dmenu for the user to select and stores the selected title in the selected_title variable.
- [ -n "$selected_title" ] && mpv "https://www.youtube.com/watch?v=$(echo "$video_info" | grep -Fw "$selected_title" | cut -f2)": If a title is selected, it finds the corresponding URL from the video_info variable and plays the video using the mpv video player.
Justification for the script:
- Highly Minimalistic: The script is concise and straightforward, making it easy to understand and maintain.
- Caching: The script stores the fetched video titles and URLs in a local cache file, reducing the need to fetch data repeatedly, which saves time and bandwidth.
- User-friendly: The script uses dmenu to provide a simple and intuitive interface for the user to interact with, allowing them to update the database and select videos with ease.
- Versatility: The script works with any YouTube channel by simply changing the CHANNEL_URL variable.
- Modular: The script is organized into separate tasks, which can be easily modified or extended to accommodate additional features or requirements.
I found a much better way of doing this, without a potentially too short sleep. This script waits for an input to be added, and then waits for a usb device to be bound. The remaps script can be run as soon as the USB device is bound. These changes should improve the reliability of the script and maybe even decrease latency.
* Fix mouse issue in firefox, add avif icon and add DK & SE to dopplar
* Update sb-doppler
* Scandinavian countries listed
---------
Co-authored-by: Victor Risgaard <victor@risgaard.xyz>
* Don't stop mounter script on ls error
If no decrypted LUKS drives are found, the script errors with `ls: cannot access '/dev/disk/by-id/dm-uuid-CRYPT-LUKS2-*': No such file or directory` and stops, this makes sure the error doesn't stop the script.
* True was on wrong line
* Programs that show ~/ or / instead of the actual working directory are now ignored by the script (except for zsh & lf where its correct). This will fix bugs where sd opens your home folder instead of the current working directory.
* This also removes the need for manually excluding all programs that don't show the correct cwd.
* git (and its sub-processes) will show the root of a repository instead of the actual cwd, so they're ignored too.