Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Impedimenta/Suitcase
A flexible command line tool for instantly deploying user interfaces for simple commands and scripts.
https://github.com/Impedimenta/Suitcase
command-line-tool developer-tools macos swiftui xcode
Last synced: 3 months ago
JSON representation
A flexible command line tool for instantly deploying user interfaces for simple commands and scripts.
- Host: GitHub
- URL: https://github.com/Impedimenta/Suitcase
- Owner: Impedimenta
- Created: 2020-04-22T19:57:57.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2020-06-13T17:29:48.000Z (over 4 years ago)
- Last Synced: 2024-11-12T16:51:02.394Z (3 months ago)
- Topics: command-line-tool, developer-tools, macos, swiftui, xcode
- Homepage: https://impedimenta.github.io
- Size: 44.1 MB
- Stars: 1,325
- Watchers: 14
- Forks: 22
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
Awesome Lists containing this project
README
# Suitcase
*A flexible command line tool for instantly deploying user interfaces for simple commands and scripts.*
[data:image/s3,"s3://crabby-images/b713d/b713d7c2de7d3e6f2a6850bb49650f799ff060d9" alt="GitHub release (latest SemVer)"](https://github.com/Impedimenta/Suitcase/releases) data:image/s3,"s3://crabby-images/6bb69/6bb6949000687e20919730a5051b57b246b1e86d" alt="Platform: macOS 10.15" data:image/s3,"s3://crabby-images/be53c/be53c7dcfae189c06da3a38ae5558c7d4d467125" alt="Twitter Follow" data:image/s3,"s3://crabby-images/61a06/61a0652337044218afd7d29c77a5fe53f40b24ff" alt="Twitter Follow"
Suitcase is a command line tool that can be *"programmed"* to display a [SwiftUI](https://developer.apple.com/xcode/swiftui/) interface that can trigger commands and scripts.
[𧳠Suitcase Direct Download](https://github.com/Impedimenta/Suitcase/releases/latest/download/Suitcase.dmg)
It's similar to [Shortcuts](https://apps.apple.com/us/app/shortcuts/id915249334), but for macOS and driven by the command line.
data:image/s3,"s3://crabby-images/416db/416db69ebec1c768423fb72f91785d828e66ef69" alt="Suitcase Demo Reel"
### First Class Mac Citizen
Because of its [SwiftUI](https://developer.apple.com/xcode/swiftui/) underpinnings Suitcase is a first class Mac citizen. With out of the box support for, [Dark Mode](https://support.apple.com/en-gb/HT208976), [Menubars](https://developer.apple.com/design/human-interface-guidelines/macos/menus/menu-bar-menus/) and [Drag and Drop](https://developer.apple.com/design/human-interface-guidelines/macos/user-interaction/drag-and-drop/).
### Powerful
Its power and flexibility come form the tried and trusted UNIX command line. Anything you can do in Terminal you can do in Suitcase, but with a UI and export the command as a `.command` file, to check in with a project or [share with the world](https://github.com/Impedimenta/Suitcase-Bazaar).
## Information
- [@SuitcaseCLI](https://twitter.com/SuitcaseCLI) β Regular posts about updates and examples
- [The Bazaar](https://impedimenta.github.io/Suitcase-Bazaar) β Examples and documentation
- [Impedimenta](https://impedimenta.github.io/) β Blog posts, links and related projects
- [@ImpedimentaCode](https://twitter.com/ImpedimentaCode) β Infrequent posts about other projects and tools
- [@rjstelling](https://twitter.com/rjstelling) β Frequent, irrelevant mostly technology and politics, open DMs## Command-Line Utility
### Usage
OVERVIEW: A flexible command line tool for instantly deploying user interfaces
for simple commands and scripts.USAGE: Suitcase
OPTIONS:
--version Show the version.
-h, --help Show help information.SUBCOMMANDS:
basic Launch a basic Suitcase process, that has a main menu
and an icon in the Dock when running.
utility Launch a utility Suitcase process, without a Dock
icon or main menu.#### Suitcase `basic`
A `basic` Suitcase process has a [main menu](https://developer.apple.com/documentation/appkit/nsapplication/menus) and an [icon in the Dock](https://developer.apple.com/documentation/appkit/nsdocktile) when running.
See the [full documentation](./Basic.md).
#### Suitcase utility
A `utility` Suitcase process does not have a Dock icon or main menu. It consists of just a [main window](https://developer.apple.com/documentation/appkit/nswindow).
See the [full documentation](./Utility.md).
### Examples
These examples are very basic but should give you a good idea of how you can use Suitcase. More details examples can be found at the [Bazaar](https://impedimenta.github.io/Suitcase-Bazaar/Examples/). If you have any questions please [create an issue](https://github.com/Impedimenta/Suitcase/issues). If you create a command and you'd like to share it, [open a PR at the Bazaar](https://github.com/Impedimenta/Suitcase-Bazaar).
#### Hello World
[data:image/s3,"s3://crabby-images/4b947/4b947d98d2e43ae8e007b20f58a2125feb027dcf" alt="Hello World"](https://vimeo.com/413136057)
A simple example consisting of one button that when clicked calls the `say` command. [Watch the video of this example in action](https://vimeo.com/413136057), there is a [detailed `say` example](https://impedimenta.github.io/Suitcase-Bazaar/Examples/Say.html) at the [Suitcase Bazaar](https://github.com/Impedimenta/Suitcase-Bazaar/).
π Code
```bash
$ Suitcase --name="Demo App" --window-title="Hello World" \
--window-width="200" --window-height="200" \
--control-type="label" --control-title="Give a face to every voiceβ¦" \
--control-type="button" \
--control-title="π£ Say hello" \
--control-action="/usr/bin/say Hello World"
```
#### War Gamesdata:image/s3,"s3://crabby-images/c7309/c73093aa47e94bb28a99da0a186f2fe018db384f" alt="War Games"
A more advanced example using buttons and passing parameters to the `say` command. A [detailed explanation of War Games](https://impedimenta.github.io/Suitcase-Bazaar/Examples/WarGames.html) can be found at the [Suitcase Bazaar](https://github.com/Impedimenta/Suitcase-Bazaar/).
π Code
```bash
$ Suitcase --name="War Games" \
--control-title="Shall we play a game?" \
--control-type="text-field" \
--control-identifier="say.textfield" \
--control-title="Daniel" \
--control-type="button" \
--control-group-identifier="g.btns" \
--control-action="/usr/bin/say" \
--control-action-parameter="-v,Daniel,say.textfield" \
--control-title="Samantha" \
--control-type="button" \
--control-group-identifier="g.btns" \
--control-action="/usr/bin/say" \
--control-action-parameter="-v,Samantha,say.textfield" \
--control-title="Veena" \
--control-type="button" \
--control-group-identifier="g.btns" \
--control-action="/usr/bin/say" \
--control-action-parameter="-v,Veena,say.textfield"
```#### Menus
[data:image/s3,"s3://crabby-images/05f06/05f06cc079fe1eae3b0bdac829bee20a30001d1a" alt="Menus"](https://vimeo.com/413141354)
This example shows how to create menus and sub-menus. Actions can be attached to any menu item the same way as `button`s. [Watch the video of this example in action.](https://vimeo.com/413141354)
Menu items can also be assigned a keyboard shortcut. See the [full documentation](./Basic.md) for more details.
π Code
```bash
$ Suitcase --name="Demo App" --window-title="Menus" \
--control-title="UUID" \
--control-type="label" --control-identifier="com.label.uuid" \
--menu-title="Action>Generate>UUID" \
--menu-action="/usr/bin/uuidgen" \
--menu-action-destination="com.label.uuid" \
--menu-title="Action>Copy UUID" \
--menu-shortcut="k" \
--menu-action="/usr/bin/printenv com.label.uuid | /usr/bin/pbcopy"
```#### Hidden Files & Folders
[data:image/s3,"s3://crabby-images/ed16d/ed16d2b9ccff7329d913bbfc67e61cc6e38d237e" alt="Hidden Files & Folders"](https://vimeo.com/413199912)
This is a more involved example that uses `defaults` to read the macOS user defaults system and use `sed` to set a state `label`. [Watch the video of this example in action.](https://vimeo.com/413199912)
π Code
```bash
$ Suitcase --name="Hidden Finder Settings" \
--control-title="Hidden Files & Folders:" \
--control-group-identifier="com.finder.hidden" \
--control-type="label" \
--control-title="unknown" \
--control-group-identifier="com.finder.hidden" \
--control-type="label" \
--control-identifier="com.label.hidden.state" \
--control-title="Refresh" \
--control-group-identifier="com.finder.hidden" \
--control-type="button" \
--control-action="/usr/bin/defaults read com.apple.finder AppleShowAllFiles | /usr/bin/sed s/1/Visible/g;s/0/Hidden/g" \
--control-action-destination="com.label.hidden.state" \
--control-title="Enable" \
--control-type="button" \
--control-group-identifier="com.finder.hidden.buttons" \
--control-action="/usr/bin/defaults write com.apple.finder AppleShowAllFiles -bool TRUE & /usr/bin/killall Finder" \
--control-title="Disable" \
--control-type="button" \
--control-group-identifier="com.finder.hidden.buttons" \
--control-action="/usr/bin/defaults write com.apple.finder AppleShowAllFiles -bool FALSE & /usr/bin/killall Finder"
```This is how the command would be run in Terminal.
```bash
$ defaults read com.apple.finder AppleShowAllFiles | sed 's/1/Visible/g;s/0/Hidden/g'
```The button uses `&` to run two commands, one to write to the user defaults and the second to relaunch the Finder:
```bash
$ defaults write com.apple.finder AppleShowAllFiles -bool TRUE
```Kill the Finder and relaunch:
```bash
$ killall Finder
```## Suitcase
### Export as a `.command`
Any Suitcase command can be exported as a self running `.command` file. You can double click this file to launch the Suitcase or share the file (it's just plain text).
data:image/s3,"s3://crabby-images/47438/474380cb101c54ae35389feef78f1ab79c463304" alt="Export Command"
## Bug Reports & Feature Requests
Please [create an issue](https://github.com/Impedimenta/Suitcase/issues).
## Contact
Releases and News ([@SuitcaseCLI](https://twitter.com/SuitcaseCLI))
Richard Stelling ([@rjstelling](https://twitter.com/rjstelling))## Thanks to
- [Dave Verwer](https://github.com/daveverwer) at [iOS Dev Weekly](https://iosdevweekly.com)