custom_keybinding_actions/
custom_keybinding_actions.rs

1extern crate skim;
2use skim::prelude::*;
3
4// No action is actually performed on your filesystem!
5// This example only produce friendly print statements!
6
7fn fake_delete_item(item: &str) {
8    println!("Deleting item `{}`...", item);
9}
10
11fn fake_create_item(item: &str) {
12    println!("Creating a new item `{}`...", item);
13}
14
15pub fn main() {
16    // Note: `accept` is a keyword used define custom actions.
17    // For full list of accepted keywords see `parse_event` in `src/event.rs`.
18    // `delete` and `create` are arbitrary keywords used for this example.
19    let options = SkimOptionsBuilder::default()
20        .multi(true)
21        .bind(vec!["bs:abort", "Enter:accept"])
22        .build()
23        .unwrap();
24
25    if let Some(out) = Skim::run_with(&options, None) {
26        match out.final_key {
27            // Delete each selected item
28            Key::Backspace => out.selected_items.iter().for_each(|i| fake_delete_item(&i.text())),
29            // Create a new item based on the query
30            Key::Enter => fake_create_item(out.query.as_ref()),
31            _ => (),
32        }
33    }
34}