Command Line Interfaces (CLIs), though graphically limited due to terminal capabilities, can still benefit significantly from well-designed and consistent aesthetics across various commands. This is a role traditionally filled by design systems in Graphical User Interfaces (GUIs), but it remains largely unexplored in the context of terminals.
Tuist's terminal experiences, for a long time, suffered from the lack of a design system, leading to issues like inconsistent spacing, information overload, and difficult-to-parse outputs. This situation motivated us to create SwiftTerminal, a design system specifically for Swift-powered CLIs.
Noora offers a set of aesthetically pleasing, customizable, and uniform design system for crafting terminal experiences. It encapsulates our extensive experience in crafting the Tuist CLI. We are delighted to share it with the Swift community, aiming to make building terminal experiences an enjoyable process.
Note
The project is currently in an early stage of development. Our plan is to create a basic set of components and then iterate on them based on the feedback we receive from the community.
Add Noora
as a dependency of your project:
import PackageDescription
let package = Package(
name: "Noora",
platforms: [.macOS("12.0")],
products: [
/** Your products **/
],
dependencies: [
.package(url: "https://github.com/tuist/Noora", .upToNextMajor(from: "0.15.0")),
],
targets: [
/** Your targets **/
]
)
Then you can start using Noora.
You need to create an instance of Noora
first, and then every component available is represented as a function in the Noora
instance.
Noora().yesOrNoChoicePrompt(
title: "Authentication",
question: "Would you like to authenticate?",
defaultAnswer: true,
description: "Authentication is required to use some CLI features."
)
Check out our documentation to see the components and their usage.
- Clone the repository:
git clone https://github.com/tuist/Noora.git
- Generate the project:
tuist generate
- Clone the repository:
git clone https://github.com/tuist/Noora.git
- Open the
Package.swift
with Xcode
To see the components and their usage, visit the documentation website.