mirror of
https://github.com/wez/wezterm.git
synced 2025-01-05 20:43:57 +03:00
229df874b7
Take the existing open-uri docs and move to their own page. Add docs for the new window events.
40 lines
1.2 KiB
Markdown
40 lines
1.2 KiB
Markdown
# `open-uri`
|
|
|
|
The `open-uri` event is emitted when the `CompleteSelectionOrOpenLinkAtMouseCursor`
|
|
key/mouse assignment is triggered.
|
|
|
|
The default action is to open the active URI in your browser, but if you
|
|
register for this event you can co-opt the default behavior.
|
|
|
|
For example, if you prefer to launch your preferred MUA in a new window
|
|
in response to clicking on `mailto:` URLs, you could do something like:
|
|
|
|
```lua
|
|
local wezterm = require 'wezterm';
|
|
|
|
wezterm.on("open-uri", function(window, pane, uri)
|
|
local start, match_end = uri:find("mailto:")
|
|
if start == 1 then
|
|
local recipient = uri:sub(match_end+1)
|
|
window:perform_action(wezterm.action{SpawnCommandInNewWindow={
|
|
args={"mutt", recipient}
|
|
}}, pane);
|
|
-- prevent the default action from opening in a browser
|
|
return false
|
|
end
|
|
-- otherwise, by not specifying a return value, we allow later
|
|
-- handlers and ultimately the default action to caused the
|
|
-- URI to be opened in the browser
|
|
end)
|
|
```
|
|
|
|
The first event parameter is a [`window` object](../window/index.md) that
|
|
represents the gui window.
|
|
|
|
The second event parameter is a [`pane` object](../pane/index.md) that
|
|
represents the pane.
|
|
|
|
The third event parameter is the URI string.
|
|
|
|
|