Swift Package of Closure based Tasks, used by Menus, Toolbars, Touchbars & Buttons for Macintosh App development (Cocoa).
- MacOS 10.15
- Swift 5
- Xcode 11
https://github.com/magesteve/SlamTaskSpellBook
Refer to code documentation for explanation for specific calls.
Abstract Structure for SlamTaskSpellBook. It supports some aliases.
Structure with details of invoking item (MenuItem, ToolbarItem, Button). Each structure contains the name of the task, with associated word (string) & tag (int). Most of the closure for a task have this structure as a parameter. When the task is invoked, the Info usually reflects the fields of the Button/ToolbarItem/MenuItem that invoked the Task. For example, two menu items can have the same Task (ex: "openurl"), with different word parameters (ex: "apple.com" vs "github.com". Then each Task would cause a different webpage to appear.
SlamTask is single task to complete. It uses closures to invoke and display the task. The "action" closure is called when the task need to run, the "valid" is called to determine if the task is available, the "mark" closure returns true if the task should be checked (ala Menu), and the "label" closure returns the display name of the task. All save the first "action" tasks are optional/ A title is used to identify the task.
Protocol for Controllers of tasks (NSWindowController, NSViewController, NSDocument). For a controller to be able to invoke a task by a given title, it must maintain a list of Tasks. This protocol has a single required variable listTasks of type SlamTaskList (list of tasks). Extension to this protocol check is a given task with given tittle is in the list.
App Delegate protocol for those that support SlamTasks. This is a sub protocol of SlamTaskBossProtocol, with similar requirement. It has additional extension specific to being an App Delegate.
Task based version of Menus (subclass of NSMenuItem). It has IBInspectable title (string), word (string) & tag (Int). There is no need to attach this menu to any IBAction. When the user selects it, the Task with the associated title will be invoked. If the optional closure that affect appearance (validate, mark, label) are not nil, they are invoked to change the item's appearance.
Task based version of Toolbar Item (subclass of NSToolbarItem). It has IBInspectable title (string), word (string) & tag (Int). There is no need to attach this menu to any IBAction. When the user selects it, the Task with the associated title will be invoked. If the optional closure that affect appearance (validate, mark, label) are not nil, they are invoked to change the item's appearance.
Task based version of button (subclass of NSButton). It has IBInspectable title (string), word (string) & tag (Int). There is no need to attach this menu to any IBAction. When the user selects it, the Task with the associated title will be invoked. Only if the static function slamTaskButtonPrepare(button:) is called, will the optional appearance closures try to change the appearance of the button.
SlamTaskButtons can be used with Touchbar & Touchbar Button Items. After creating a Touchbar, drag a touchbar item with a button on it, into the touchbar. This places a NSTouchbarItem containing NSView it, that contains a normal NSButton. Then change the NSButton to SlamTaskButton. Configure it normally, and it will just work.
Sample code using this SpellBook can be found in the open-source Cocoa App CocoaGrimoire. Other SpellBooks by the author are also demonstrated there.
CocoaSpellBook is available as open source under the terms of the MIT License.