# Terminal.Gui UI Catalog UI Catalog is a comprehensive sample library for Terminal.Gui. It attempts to satisfy the following goals: 1. Be an easy-to-use showcase for Terminal.Gui concepts and features. 2. Provide sample code that illustrates how to properly implement said concepts & features. 3. Make it easy for contributors to add additional samples in a structured way. ![screenshot](screenshot.png) ## Motivation The original `demo.cs` sample app for Terminal.Gui is neither good to showcase, nor does it explain different concepts. In addition, because it is built on a single source file, it has proven to cause friction when multiple contributors are simultaneously working on different aspects of Terminal.Gui. See [Issue #368](https://github.com/giu-cs/Terminal.Gui/issues/368) for more background. # API Reference * [UI Catalog API Reference](https://gui-cs.github.io/Terminal.Gui/api/UICatalog/UICatalog.html) ## How To Use Build and run UI Catalog by typing `dotnet run` from the `UI Catalog` folder or by using the `Terminal.Gui` Visual Studio solution. `Program.cs` is the main **UI Catalog** app and provides a UI for selecting and running **Scenarios**. Each **Scenario* is implemented as a class derived from `Scenario` and `Program.cs` uses reflection to dynamically build the UI. **Scenarios** are tagged with categories using the `[ScenarioCategory]` attribute. The left pane of the main screen lists the categories. Clicking on a category shows all the scenarios in that category. **Scenarios** can be run either from the **UICatalog.exe** app UI or by being specified on the command line: ``` UICatalog.exe ``` e.g. ``` UICatalog.exe Buttons ``` Hitting ENTER on a selected Scenario or double-clicking on a Scenario runs that scenario as though it were a stand-alone Terminal.Gui app. When a **Scenario** is run, it runs as though it were a standalone `Terminal.Gui` app. However, scaffolding is provided (in the `Scenario` base class) that (optionally) takes care of `Terminal.Gui` initialization. ## Contributing by Adding Scenarios To add a new **Scenario** simply: 1. Create a new `.cs` file in the `Scenarios` directory that derives from `Scenario`. 2. Add a `[ScenarioMetaData]` attribute to the class specifying the scenario's name and description. 3. Add one or more `[ScenarioCategory]` attributes to the class specifying which categories the sceanrio belongs to. If you don't specify a category the sceanrio will show up in "All". 4. Implement the `Setup` override which will be called when a user selects the scenario to run. 5. Optionally, implement the `Init` and/or `Run` overrides to provide a custom implementation. The sample below is provided in the `.\UICatalog\Scenarios` directory as a generic sample that can be copied and re-named: ```csharp using Terminal.Gui; namespace UICatalog { [ScenarioMetadata (Name: "Generic", Description: "Generic sample - A template for creating new Scenarios")] [ScenarioCategory ("Controls")] class MyScenario : Scenario { public override void Setup () { // Put your scenario code here, e.g. Win.Add (new Button () { Text = "Press me!", X = Pos.Center (), Y = Pos.Center (), Clicked = () => MessageBox.Query (20, 7, "Hi", "Neat?", "Yes", "No") }); } } } ``` `Scenario` provides `Win`, a `Window` object that provides a canvas for the Scenario to operate. The default `Window` shows the Scenario name and supports exiting the Scenario through the `Esc` key. ![screenshot](generic_screenshot.png) To build a more advanced scenario, where control of the `Toplevel` and `Window` is needed (e.g. for scenarios using `MenuBar` or `StatusBar`), simply use `Application.Top` per normal Terminal.Gui programming, as seen in the `Notepad` scenario. For complete control, the `Init` and `Run` overrides can be implemented. The `base.Init` creates `Win`. The `base.Run` simply calls `Application.Run(Application.Top)`. ## Contribution Guidelines - Provide a terse, descriptive `Name` for `Scenarios`. Keep them short. - Provide a clear `Description`. - Comment `Scenario` code to describe to others why it's a useful `Scenario`. - Annotate `Scenarios` with `[ScenarioCategory]` attributes. Minimize the number of new categories created. - Use the `Bug Repo` Category for `Scenarios` that reproduce bugs. - Include the Github Issue # in the Description. - Once the bug has been fixed in `develop` submit another PR to remove the `Scenario` (or modify it to provide a good regression test/sample). - Tag bugs or suggestions for `UI Catalog` as [`Terminal.Gui` Github Issues](https://github.com/gui-cs/Terminal.Gui/issues) with "UICatalog: ".