When working with feature branches, stale branches pile up over time. It's best to remove them right after merge, locally and on the remote, but it is a little tedious: you need to remember it, and perform the few steps manually each time.
Enter Git hooks. The folks at Liquid Light have built a little post-merge hook that will delete a feature branch on confirmation Show archive.org snapshot .
Quick aside: Git hooks location
Git hooks are normally stored in the current repository, at .git/hooks/. They are not checked in and will not be shared with others.
If you prefer to manage your hooks globally, i.e. have a single set of hooks that applies to all your repositories, you can 
  change the Git hooks location
  
    Show archive.org snapshot
  
: git config --global core.hooksPath /path/to/my/centralized/hooks.
The post-merge hook
Create a post-merge file in your hooks directory (see above). Paste this:
#!/bin/bash
exec < /dev/tty
# Get the current branch name
branch_name=$(git branch --show-current)
# Get the name of the branch that was just merged
reflog_message=$(git reflog -1)
merged_branch_name=$(echo $reflog_message | cut -d" " -f 4 | sed "s/://")
if [[ "$merged_branch_name" == "@{-1}" ]]; then
  # Somebody merged "-", the previous branch. Resolve it to the actual branch
  # name.
  merged_branch_name=$(git name-rev @{-1} --name-only)
fi
# Don't offer branch deletion for some branch names
if [[ "$merged_branch_name" =~ ^(master|main|production|Fast-forward)$ ]]; then
    exit 0
fi
# Begin output
echo " "
echo "> You have just merged the branch \"$merged_branch_name\" into \"$branch_name\". "
# Ask the question                                                              
read -p "> Do you want to push \"$branch_name\" + delete the \"$merged_branch_name\" branch? (y/N) " answer
                                                                                
if [[ "$answer" == "y" ]]; then                                                 
    git push                                                                    
    # Delete the local branch
    git branch -d $merged_branch_name
    echo "> Deleting remote branch ..."
    git push origin --delete $merged_branch_name
    exit 1
else
    echo "x Did not delete the \"$merged_branch_name\" branch."
fi
Save the file and make it executable: chmod +x path/to/post-merge
Now, after merging a branch, you will be asked if you would like to have the branch deleted:
$ git merge ds/foo
Updating 338e82e38..2d4269c81
Fast-forward
 foo | 0
 1 file changed, 0 insertions(+), 0 deletions(-)
 create mode 100644 foo
 
> You have just merged the branch "ds/foo" into "master". 
> Do you want to push "master" + delete the "ds/foo" branch? (y/N) y
To github.com
   abc123..def456 master -> master
Deleted branch ds/foo (was 2d4269c81).
Deleting remote branch ...
- [deleted] ds/foo