Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Clipy/Magnet
Customize global hotkeys in macOS.
https://github.com/Clipy/Magnet
alfred clipy dvorak hotkey macos qwerty sandbox shortcut swift
Last synced: 4 months ago
JSON representation
Customize global hotkeys in macOS.
- Host: GitHub
- URL: https://github.com/Clipy/Magnet
- Owner: Clipy
- License: mit
- Created: 2016-03-08T15:07:28.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2024-08-22T20:40:29.000Z (6 months ago)
- Last Synced: 2024-10-01T04:57:46.986Z (5 months ago)
- Topics: alfred, clipy, dvorak, hotkey, macos, qwerty, sandbox, shortcut, swift
- Language: Swift
- Homepage: https://clipy-app.com
- Size: 184 KB
- Stars: 424
- Watchers: 10
- Forks: 44
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
# Magnet
data:image/s3,"s3://crabby-images/8550d/8550d973f94fe5a7e2e844362ef830d0a891e85a" alt="CI"
[data:image/s3,"s3://crabby-images/0dde1/0dde1caa7e0f82f3d35a59635e69f8fc4baac915" alt="Release version"](https://github.com/Clipy/Magnet/releases/latest)
[data:image/s3,"s3://crabby-images/a544b/a544bd99a6a7634094250658f71e7ebea58cdc15" alt="License: MIT"](https://github.com/Clipy/Magnet/blob/master/LICENSE)
[data:image/s3,"s3://crabby-images/2d180/2d1801ae7805458b91e18c5ac4d97d63da45be3a" alt="Carthage compatible"](https://github.com/Carthage/Carthage)
[data:image/s3,"s3://crabby-images/b2e8a/b2e8ab467cb7e7d4bfb8bfd9b2ad90e529a42f63" alt="Version"](http://cocoadocs.org/docsets/Magnet)
[data:image/s3,"s3://crabby-images/72449/72449779b7260198b34dd3e5a872affbe18407ae" alt="Platform"](http://cocoadocs.org/docsets/Magnet)
[data:image/s3,"s3://crabby-images/96a9a/96a9af40725489461c2d067f886ec6267f42b3e3" alt="SPM supported"](https://swift.org/package-manager)Customize global hotkeys in macOS. Supports usual hotkey and double tap hotkey like Alfred.app.
Also supports sandbox application.
## Usage
### CocoaPods
```
pod 'Magnet'
```### Carthage
```
github "Clipy/Magnet"
```## Upgrading from Magnet v2.x to v3.x
See [Upgrading from Magnet v2.x](/Documentation/Upgrading_Magnet_2.md)## Example
### Register Normal hotkey
Add `⌘ + Control + B` hotkey.```swift
if let keyCombo = KeyCombo(key: .b, cocoaModifiers: [.command, .control]]) {
let hotKey = HotKey(identifier: "CommandControlB", keyCombo: keyCombo, target: self, action: #selector())
hotKey.register() // or HotKeyCenter.shared.register(with: hotKey)
}
```Or you can use closures.
```swift
if let keyCombo = KeyCombo(key: .b, cocoaModifiers: [.command, .control]) {
let hotKey = HotKey(identifier: "CommandControlB", keyCombo: keyCombo) { hotKey in
// Called when ⌘ + Control + B is pressed
}
hotKey.register()
}
```### Register Double tap hotkey
Add `⌘ double tap` hotkey.
```swift
if let keyCombo = KeyCombo(doubledCocoaModifiers: .command) {
let hotKey = HotKey(identifier: "CommandDoubleTap", keyCombo: keyCombo, target: self, action: #selector())
hotKey.register() // or HotKeyCenter.shared.register(with: hotKey)
}
```Add `Control double tap` hotkey.
```swift
if let keyCombo = KeyCombo(doubledCarbonModifiers: controlKey) {
let hotKey = HotKey(identifier: "ControlDoubleTap", keyCombo: keyCombo, target: self, action: #selector())
hotKey.register() // or HotKeyCenter.shared.register(with: hotKey)
}
```#### Support modifiers
Double tap hotkey only support following modifiers.
- Command Key
- `NSEventModifierFlags.command` or `cmdKey`
- Shift Key
- `NSEventModifierFlags.shift` or `shiftKey`
- Option Key
- `NSEventModifierFlags.option` or `optionKey`
- Control Key
- `NSEventModifierFlags.control` or `controlKey`### Unregister hotkeys
```swift
HotKeyCenter.shared.unregisterAll()
```or
```swift
HotKeyCenter.shared.unregisterHotKey(with: "identifier")
```or
```swift
let hotKey = HotKey(identifier: "identifier", keyCombo: KeyCombo, target: self, action: #selector())
hotKey.unregister() // or HotKeyCenter.shared.unregister(with: hotKey)
```## Dependencies
- [Sauce](https://github.com/Clipy/Sauce)## How to Build
1. Move to the project root directory
2. Install dependency library with `carthage` or `git submodule`
3. `carthage checkout --use-submodules` or `git submodule update --init --recursive`
4. Open `Magnet.xcworkspace` on Xcode.
5. build.