Releases: project-gauntlet/gauntlet
Releases · project-gauntlet/gauntlet
v10
General
- Main view now has action bar and action panel
- Action bar displays current primary action depending on focused result item
- ALT + K (OPT + K on macOS) is available to open action panel
- Content of action panel can be defined by plugins
"inline-view"
and"command-generator"
entrypoint types can now specify custom actions on main view- Plugin can also provide shortcut that will be available depending on focused result item without opening the action panel
- Primary and secondary actions
- First action in action panel is now considered primary and can be run using ENTER without opening action panel
- Second action in action panel is now considered secondary and can be run using SHIFT + ENTER without opening action panel
- Works for all places that can define actions:
"inline-view"
,"command-generator"
and"view"
entrypoint types
- Action panel now supports keyboard navigation
- All bundled plugins are merged into one
- It is now possible to update plugin using "Check for updates" button in settings
Bundled plugin
Applications
- Add Flatpak application support on Linux
- Fixed no applications being shown on macOS Sequoia (15)
- Fixed crash on macOS if macOS version only contains two segments, e.g.
15.0
vs15.0.1
- Fixed some applications not having icons on macOS
Calculator
- It is now possible to copy result of calculation using primary action and its shortcut
- After copying, popup is shown to indicate that the result was copied
- Updated
numbat
dependency to 1.14.0- Notable change: "Add lowercase aliases for currency units"
Plugin API
- Plugin permissions reworked
- BREAKING CHANGE: Plugin manifest property
permissions.ffi
removed- FFI in Deno is an unstable feature
- May be brought back in future
- BREAKING CHANGE: Plugin manifest property
permissions.high_resolution_time
removed- This is done in preparation for Deno update, newer versions of which removed this permission
- BREAKING CHANGE: Plugin manifest property
permissions.fs_read_access
renamed topermissions.filesystem.read
- BREAKING CHANGE: Plugin manifest property
permissions.fs_write_access
renamed topermissions.filesystem.write
- BREAKING CHANGE: Plugin manifest property
permissions.run_subprocess
has been split into 2 properties:permissions.exec.command
andpermissions.exec.executable
command
is for commands onPATH
, e.g."ls"
executable
is for absolute paths to binary, e.g."/usr/bin/ls"
- BREAKING CHANGE: Windows-style paths are not allowed in plugins that do not support Windows
- BREAKING CHANGE: Unix-style paths are not allowed in plugins that do not support Linux or macOS
- BREAKING CHANGE: Plugin manifest property
permissions.network
now can only contain domain and optionally port of URL - BREAKING CHANGE: Path permissions (
permissions.filesystem.read
,permissions.filesystem.write
andpermissions.exec.executable
) now can only contain absolute paths - Path permissions (
permissions.filesystem.read
,permissions.filesystem.write
andpermissions.exec.executable
) can now contain variables which will be replaced at plugin load time- Examples:
{linux:user-home}/.local/share
,{common:plugin-cache}/my-plugin-cache
- Variables can only be used at the beginning of the path
- List of currently available variables
{macos:user-home}
- Resolves to
$HOME
, i.e./Users/<username>
- Only available if plugin supports macOS
- Resolves to
{linux:user-home}
- Resolves to
$HOME
, i.e./home/<username>
- Only available if plugin supports Linux
- Resolves to
{windows:user-home}
- Resolves to
{FOLDERID_Profile}
, i.e.C:\Users\<username>
- Only available if plugin supports Windows
- Resolves to
{common:plugin-data}
- On Windows:
{FOLDERID_RoamingAppData}\Gauntlet\data\plugins\<plugin-uuid>
- On Linux:
$XDG_DATA_HOME/gauntlet/plugins/<plugin-uuid>
- On macOS:
$HOME/Library/Application Support/dev.project-gauntlet.gauntlet/plugins/<plugin-uuid>
- On Windows:
{common:plugin-cache}
- On Windows:
{FOLDERID_LocalAppData}\Gauntlet\cache\plugins\<plugin-uuid>
- On Linux:
$XDG_CACHE_HOME/gauntlet/plugins/<plugin-uuid>
- On macOS:
$HOME/Library/Application Support/dev.project-gauntlet.gauntlet/plugins/<plugin-uuid>
- On Windows:
- Examples:
- BREAKING CHANGE: Plugin manifest property
<Grid.Item/>
'stitle
property is now optional<Grid.Item/>
have a newaccessory
property, which provides an ability to specify text and/or icon under the grid cell<List.Item/>
have a newaccessories
property, which provides an ability to specify one or multiple text and/or icon items on the right side of list item- BREAKING CHANGE:
<Action>
'stitle
property renamed tolabel
- Added
entrypoint.icon
plugin manifest property that accepts path to image inside plugin'sassets
directory - Added
showHud
function that will create a simple popup window with text provided to that function
Theming API
- BREAKING CHANGE: Current color theme version increased to
3
- BREAKING CHANGE: Current everything theme version increased to
3
UI/UX Improvements
- Grid styling refined
- Inline view styling refined
- Plugin and entrypoint names of rendered inline view are now shown above that inline view
- Made color of text slightly more bright
- Focused (by keyboard navigation) and hovered (by hovering with mouse) search items now have distinct styling
- Slightly increased size of icons in main search view
- Plugin ID is now shown in sidebar in settings when plugin is selected
- "Remove plugin" button has been moved to the bottom of the sidebar in settings
- In settings required preferences that do not have value provided or do not have default value are now highlighted
- Names of keys of shortcuts were changed from all upper-case to first letter only upper-case
Fixes
- Fixed panic when trying to stop already stopped plugin
- Fixed crash on macOS if
openssl@v3
library is not installed - Fixed inline view still being shown after main view was closed and reopened
- Fixed download info panel in settings sometimes going outside of window size and being cut off
v9
Plugin API
- New React Hooks
usePromise
- Helper to run promises in a context of React view
- Returns
AsyncState
object which containsisLoading
,error
anddata
properties
useStorage
- Helper to store data between entrypoint, plugin and application runs
- Follows API similar to
useState
built-in React Hook - Uses
localStorage
internally
useCache
- Helper to store data between entrypoint runs but will be reset when plugin or application is restarted
- Follows API similar to
useState
built-in React Hook - Uses
sessionStorage
internally
useCachedPromise
- Helper to run promises with caching done automatically
- Follows
stale-while-revalidate
caching strategy - Uses
usePromise
anduseCache
Hooks internally
useFetch
- Helper to run
fetch()
with caching done automatically - Follows
stale-while-revalidate
caching strategy - Uses
useCachedPromise
Hook internally
- Helper to run
- Add
isLoading
property on<Detail/>
,<Form/>
,<Grid/>
and<List/>
- If passed
true
the loading indicator will be shown above view content
- If passed
- BREAKING CHANGE: To use
Clipboard
api, new permissionpermissions.clipboard
is required to be specified in plugin manifestpermissions.clipboard
manifest property accepts a list that can include one or multiple of"read"
,"write"
or"clear"
values
- BREAKING CHANGE: To use plugin entrypoint of type
inline-view
, new permissionpermissions.main_search_bar
is required to be specified in plugin manifestpermissions.main_search_bar
manifest property accepts a list that can include"read"
value
- BREAKING CHANGE: Plugin and Entrypoint Preference
name
properties in plugin manifest was split into 2 propertiespreferences.name
is split intopreferences.name
andpreferences.id
entrypoint.preferences.name
is split intoentrypoint.preferences.name
andentrypoint.preferences.id
- To preserve value set by user in settings please set the previous value of
name
toid
- BREAKING CHANGE: Replaced
onSelectionChange
andid
properties on<Grid/>
and<List/>
withonClick
on<Grid.Item/>
and<List.Item/>
UI/UX Improvements
- Added ALT + K (OPT + K on macOS) label to Action Panel button in bottom panel in plugin views
- Refined styling to accommodate this change
- BREAKING CHANGE: Current color theme version increased to
2
- BREAKING CHANGE: Current everything theme version increased to
2
Applications
plugin
- Add macOS System settings items like Sound, Network, etc
- Both pre- and post-Ventura macOS settings are supported
- Fixed macOS applications, that are nested more than one directory level deep in
Applications
directory, not being added
Calculator
plugin
- Updated
numbat
dependency to 1.13.0 - Enabled currency exchange rate module
Fixes
- Fix application crash when refreshing plugin via
npm run dev
from tools - Fix plugin runtime shutting down when exception is thrown inside a promise handler
v8
Plugin API
- Command Generator functions are no longer needlessly called after every entrypoint click in main window
Fixes
- Fixed crash on Arch Linux if using AMD GPU with Vulkan not setup properly
- Still if Vulkan is not setup properly it can result in low FPS when scrolling
- In some cases installing vulkan-radeon package resolves the FPS problem
- Alternatively setting
WGPU_BACKEND=gl
environment variable may also resolve the FPS problem
- Reduced minimal required version of macOS to 11 (Big Sur)
- Fix panic when spamming enable/disable plugin or entrypoint checkbox in settings
v7
Big things
- Bundling improvements
.dmg
file is now signed, notarized and stapled, removing the need for manual manipulations on.dmg
file to be able to install Gauntlet.msi
installer for Windows is now available.tar.gz
archive for Linux now contains defaultsystemd
service,.desktop
and.png
icon file
- Added system tray icon on Windows and macOS with ability to open main or settings window, see version or quit Gauntlet
- Local plugins now always use development React bundle for better error messages at the expense of performance.
General fixes
- Fix being unable to stop plugin in various situations including when there is unresolved pending promise
- Fix
generate-sample-theme
andgenerate-sample-color-theme
CLI commands failing if config folder doesn't exist - Fix console window popping up when starting Gauntlet on Windows
Applications
plugin
- On macOS and Linux, applications are now started detached from main process, fixing situations when other applications blocked Gauntlet from exiting
UI Improvements
- Action panel and download information panel in settings are now closed when clicking outside of panel on background
API changes
- Type of
GeneratedCommand
'sicon
field changed fromicon: ArrayBuffer | undefined
toicon?: ArrayBuffer
- Default function returned from
command
andcommand-generator
entrypoints can now beasync
v6
Big things
- Wayland support
- Requires LayerShell protocol
zwlr_layer_shell_v1
to be supported by window managerzwlr_layer_shell_v1
is implemented by most window managers with the exception of Gnome
- Global Shortcut on Wayland is not yet implemented, please use
gauntlet open
CLI command to open main window
- Requires LayerShell protocol
- Style changes
- Settings UI overhaul
- Slightly tweaked colors
- Changed text selection color to make text more visible
- Other minor style changes
- Theming support
- 2 types of themes
- Color only
- Everything: Color, paddings, borders, etc
- Theming is only applied to main window
- Versioned
- Because of internally invasive nature of the themes, it is perpetually unstable feature.
Themes are versioned and only one version is supported at the same time by application, the theme will stop working as soon as version is incremented- This may change in the future
- Because of internally invasive nature of the themes, it is perpetually unstable feature.
- See THEME.md for details
- 2 types of themes
- It is now possible to change global shortcut for opening main window in settings
- Plugin shortcuts are now matched based on physical keycode, which means shortcuts now work regardless of selected keyboard layout
- It is now possible to show/hide action panel using ALT + K on Windows and Linux or OPT + K on macOS
- At the moment it is not possible to change this shortcut to different keys
- BREAKING CHANGE: Implemented actual validation of
supported_system
plugin manifest property.- If OS was not specified in
supported_system
plugin manifest property, plugin will stop loading on that OS unless plugin is cross-platform (it doesn't haveenvironment
,ffi
,fs_read_access
,fs_write_access
,run_subprocess
orsystem
permission)
- If OS was not specified in
Plugin Development
- Local plugin stdout
console.log
and stderrconsole.error
logs are now saved to file to be able to show them in tools dev server CLI - Added
windows
andmacos
values to plugins manifestsupported_system
property - BREAKING CHANGE: For local development plugins,
dist
suffix is now automatically added to plugin ID. Please update@project-gauntlet/tools
to0.6.0
- BREAKING CHANGE: Image source properties how accept path to asset, url or icon instead of byte array
- Url source at the moment is not cached, so the image is downloaded every time the view is opened
Applications
plugin
- On Linux
.desktop
files are now opened usinggtk-launch
instead of custom implementation, fixing several edge cases
UI Improvements and Fixes
- Main window list is now scrolled automatically when using keyboard navigation to keep focused item visible
- Better feedback about in-progress/failed/successful plugin downloads with information about errors in settings
General fixes
- Fix plugin toggle button to hide/show entrypoints in settings not doing anything
- Fix settings app being always on top of other windows on macOS
Internal Improvements
- Removed the need to have
42321
TCP port- Note: port
42320
is still being used
- Note: port
v5
Big things
- Style overhaul
- Window no longer changes the size in subviews. Default window size is a little bigger
- BREAKING CHANGE: Rename
management
cli option tosettings
- Add error message for settings view when unable to connect to server
Fixes
- Fix Gauntlet crash on startup on Linux
- Built-in plugins no longer re-enable themselves after restart
v4
Fixes
- Fix Gauntlet crash on startup on macOS
- Fix Gauntlet crash on startup if there is no enabled plugins
v3
Big things
- macOS support
.dmg
file is now available- Implement Applications Plugin on macOS
- Implement auto-launch on startup
- Search improvements
- Use Frecency-based sorting
- Use substring matching instead of prefix matching
- Multiple (space-separated) word queries now return intersection of results instead of union
- Startup was reworked again
- BREAKING CHANGE: Server is now started with plain
gauntlet
command instead ofgauntlet server
CLI option - When executing the binary, if server is already running, GUI will be opened
- Added
--minimized
flag to start server without opening the GUI - Frontend is now in the same process as server
- BREAKING CHANGE: Server is now started with plain
- Main view search results are now refreshed if the plugin changed search index while the view was opened
Work-in-progress Windows support
- Fix build on Windows
- Implemented auto-launch on Windows
- Use ALT + SPACE global shortcut on Windows to open main window
APIs changes
- Implemented Clipboard API
text/plain
andimage/png
are supported types of clipboards
- Remove
Detail
children component ofGrid
from TypeScript typings. It never worked
UI Improvements and Fixes
- Slightly better styling of
EmptyView
component - Remove vertical separator line in Details view when there is no Content
General fixes
- Fix panic when global shortcut functionality is not available
- Fix React warning about required
key
property whenActionPanel
component is used - Fix useEffect destructors not being called when view is closed
Internal Improvements
- Preparation for documentation web page
- Screenshot generation tool to generate screenshots for showing how UI looks for specific TS code
- Preparation for theming support
v2
Big changes
- BREAKING CHANGE: Instead of separate binary for "frontend", frontend is now started by server in separate process on initial application launch
- Global shortcut is available to show the application window. Currently, hardcoded to META + SPACE
- In case window manager or underlying library we use doesn't support global shortcuts,
gauntlet open
command is also now available - Unfortunately had to remove Wayland support for now, because GUI library we use, on Wayland doesn't support hiding/showing windows as well as setting window to be top-level
- BREAKING CHANGE: Inter-process communication protocol has been changed from
DBus
togRPC
- To be able to support macOS and Windows easier in near future
- Currently, 2 TCP ports are used and hardcoded to be
42320
and42321
- BREAKING CHANGE: Plugins and plugin entrypoints now require description to be specified in plugin manifest
gauntlet.description
andentrypoint.*.description
keys are now required- Currently, only shown in Settings
- Actions can now be executed also using shortcuts
- Shortcuts for specific entrypoint need to be specified in plugin manifest
- Plugins are allowed to use only limited set of keys for shortcuts
- Only upper and lower-case letters, symbols and numbers
- Shortcut can have either
"main"
or"alternative"
kind"main"
shortcut requires following modifiers- Windows and Linux: CTRL
- macOS: CMD
"alternative"
shortcut requires following modifiers- Windows and Linux: ALT
- macOS: OPT
- Whether SHIFT is also required depends on character specified for shortcut, e.g
$
will require SHIFT to be pressed, while4
will not
- 3 new bundled plugins
Applications
- Collects and shows list of applications from systems as
"command"
entrypoints - "Gauntlet Application Launcher can now launch applications" :)
- Currently, only works on Linux
- Collects
.desktop
files based on Desktop Entry Specification
- Collects
- Collects and shows list of applications from systems as
Calculator
- Shows result of mathematical operations directly in main view under the search bar
- Powered by Numbat
Settings
- Allows to open Gauntlet Settings from the Gauntlet itself
- Production React bundle is now used instead of Development bundle
- Better performance
- Worse error reporting
- Main window now has keyboard navigation
- It is now possible to remove plugins in Settings
- Plugin Entrypoints can now have icons
- Linux binary is now published inside
.tar.gz
file
API changes
- BREAKING CHANGE:
"command"
entrypoint now expects function as default export instead of plain JS file - BREAKING CHANGE: Removed
<Content.Link>
React Component<Content>
is now expected to only contain non-interactive elements because of usage in<Inline>
and<Grid.Item>
- BREAKING CHANGE:
<MetadataIcon>
icon
property type was changed to enum and renders to proper image of limited set of icons - New
<List>
and<Grid>
top-level React Components - New
"inline-view"
entrypoint type- A view is rendered directly under main view search bar
- Default export is expected to be a React Component that takes
text
string with current value of main search bar as single property - Child component is expected to be of type
<Inline>
- Used to implement built-in
Calculator
plugin but also available for any plugins to use
- New
"command-generator"
entrypoint type- Allows plugins to provide dynamically generated list of
"command"
entrypoints - Used to implement built-in
Applications
plugin but also available for any plugins to use
- Allows plugins to provide dynamically generated list of
- New
useNavigation
React Hook. Simple stack based navigation in plugins - Plugins and plugin entrypoints can now have preferences
- Need to be declared in plugin manifest
- Values can be set either on first plugin/entrypoint usage (if preference is required) or in Settings
pluginPreferences
andentrypointPreferences
helper functions to retrieve values
- Plugins now have ability to provide assets in
assets
directory which later can be retrieved in JS using newassetData
helper function - Add
"title"
property toCheckbox
React Component- It is shown to the right of the checkbox in forms
<Image>
is now properly implemented and hassource
prop of typeImageSource
which is object that contains image binary data
UI/UX Improvements and Fixes
- Application window is now always show on top of all other windows
- Application now requests focus when the window is opened
- Application window is now re-centered when opening any plugin-rendered view
- Needed because plugin-rendered views make window bigger causing it to be not centered
- Show error in GUI when React rendering fails either because of plugin or Gauntlet itself
- Text now flows and wraps properly if multiple separate strings were passed as children parameter to
<Paragraph>
React Component - Entrypoint name is now shown at the bottom of every plugin-rendered view
- Clicking on
<Detail.Metadata.Link>
now properly opens links in your default browser - Plugin name in main view has been moved to the right side of the window
v1
Added
- Initial release.