TerminalGuiDesigner 1.0.14
See the version list below for details.
dotnet tool install --global TerminalGuiDesigner --version 1.0.14
dotnet new tool-manifest
dotnet tool install --local TerminalGuiDesigner --version 1.0.14
#tool dotnet:?package=TerminalGuiDesigner&version=1.0.14
nuke :add-package TerminalGuiDesigner --version 1.0.14
Terminal Gui Designer
Cross platform designer for Terminal.Gui applications.
Built with CodeDom and Roslyn, TerminalGuiDesigner lets you create complicated Views with drag and drop just like the WinForms designer you know and love (or hate).
Install the tool from NuGet or follow the Hello World Tutorial:
dotnet tool install --global TerminalGuiDesigner
Update to the latest version using
dotnet tool update --global TerminalGuiDesigner
This project is in alpha. See the feature list for progress.

Building
Build using the dotnet 6.0 sdk
cd src
dotnet run
Usage
Install the dotnet sdk and create a new console application with references to Terminal.Gui. Install the TerminalGuiDesigner and create a new dialog:
dotnet new console -n hello
cd hello
dotnet add package Terminal.Gui
dotnet tool install --global TerminalGuiDesigner
TerminalGuiDesigner MyDialog.cs
Enter a namespace then add a Button to the view. Save with Ctrl+S. Exit the designer with Ctrl+Q.
Enter the following into Program.cs
using Terminal.Gui;
Application.Init();
Application.Run(new YourNamespace.MyDialog());
Application.Shutdown();
Run your program with
dotnet run
You can add new code to MyDialog.cs but avoid making any changes to MyDialog.Designer.cs as this will be rewritten when saving.
For example in MyDialog.cs after InitializeComponent() add the following:
button1.Clicked += ()=>MessageBox.Query("Hello","Hello World","Ok");
Now when run clicking the button will trigger a message box.

You can re-open the designer by running it from the command line with the file you want to edit/create.
TerminalGuiDesigner MyDialog.cs
You can remove the tool using the following:
dotnet tool uninstall --global TerminalGuiDesigner
Keybindings & Controls
You can change keybindings by copying Keys.yaml into your current directory.
To edit MenuBar items use the following controls
| Key | Action | 
|---|---|
| Shift Up/Down | Move selected menu item up/down | 
| Shift Right | Move selected menu item to a submenu of the one above | 
| Shift Left | Move selected sub menu item up a level | 
| Del | Remove selected menu item | 
| Enter | Add a new menu item | 
| Typing | Edit the Title of the selected item | 
| Ctrl + T | Set Shortcut | 
| Ctrl + R | Set menu field name | 
New root level menus can be added by right clicking the MenuBar and selecting 'Add Menu'.
You can create a menu separator by typing ---
Features
The following feature list shows the current capabilities and the roadmap
-  Design classes
- Window
- Dialog
- View
- Top level (with statusbar and or menu)
 
- Configure root properties (e.g. Window.Width, Title etc)
-  Configure subview properties
- (Name)
- X/Y
- Width/Height
- Text
- Color Schemes
 
-  Mouse Input
- Drag to move
- Drag into/out of sub view
- Drag to resize
 
- Undo/Redo
- Direct editing of Text just by typing
-  Easy Menu Bar Designing
- Create new items
- Move items
- Move in/out of submenus
- Add menu bar separators (Type '---')
- Assign shortcuts
-  Set fieldnames (Name)
 
- Easy Status Bar Designing
- Create Events e.g. MyButton_OnClick
-  Mutli select
- Multi delete
- Multi keyboard move
- Multi mouse drag move
- Multi set Property
- Multi Copy/Paste
 
-  Copy/Paste
- Single simple views
- Complex Views (TableView, MenuBar etc)
- To OS clipboard (e.g. open one Designer.cs View and copy to another)
 
-  Move views to subviews
- With mouse
- With keyboard
 
- Read and present xmldoc comments when editing properties
-  Dev Environment Integration
- Visual Studio plugin (e.g. right click a .Designer.cs to open in TerminalGuiDesigner console)
- Visual Studio Code plugin
 
- Comprehensive Tests
- CI
-  Create and edit views
- Button
- Checkbox
- ComboBox
- DateField
- FrameView
- GraphView
- HexView
- Label
- LineView
- ListView
- MenuBar
- PanelView
- ProgressBar
- RadioGroup
- StatusBar
- TableView
- TabView
- TextField
- TextValidateField
- TextView
- TimeField
- TreeView
- View
 
Class Diagram
| Product | Versions Compatible and additional computed target framework versions. | 
|---|---|
| .NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. | 
This package has no dependencies.
| Version | Downloads | Last Updated | 
|---|---|---|
| 2.0.0-develop.4538 | 235 | 9/5/2025 | 
| 2.0.0-develop.4519 | 359 | 6/30/2025 | 
| 2.0.0-develop.4402 | 179 | 6/24/2025 | 
| 2.0.0-develop.4401 | 1,367 | 3/22/2025 | 
| 2.0.0-develop.4400 | 108 | 3/21/2025 | 
| 2.0.0-alpha.2203 | 1,118 | 8/24/2024 | 
| 2.0.0-alpha.2189 | 139 | 8/23/2024 | 
| 1.1.1 | 1,753 | 3/14/2025 | 
| 1.1.0 | 4,687 | 12/2/2023 | 
| 1.1.0-rc1 | 266 | 12/1/2023 | 
| 1.0.25 | 945 | 9/8/2023 | 
| 1.0.24 | 1,711 | 4/7/2023 | 
| 1.0.23 | 3,684 | 2/6/2023 | 
| 1.0.22 | 628 | 1/24/2023 | 
| 1.0.21 | 552 | 1/24/2023 | 
| 1.0.20 | 780 | 11/21/2022 | 
| 1.0.19 | 588 | 11/13/2022 | 
| 1.0.18 | 1,062 | 8/29/2022 | 
| 1.0.17 | 1,166 | 8/3/2022 | 
| 1.0.16 | 1,007 | 7/25/2022 | 
| 1.0.15 | 1,069 | 7/2/2022 | 
| 1.0.14 | 836 | 6/29/2022 | 
| 1.0.13 | 853 | 6/22/2022 | 
| 1.0.12 | 804 | 6/18/2022 | 
| 1.0.11 | 850 | 6/18/2022 | 
| 1.0.10 | 823 | 6/11/2022 | 
| 1.0.9 | 880 | 5/25/2022 | 
| 1.0.8 | 887 | 5/17/2022 | 
| 1.0.7 | 834 | 5/8/2022 | 
| 1.0.6 | 827 | 4/24/2022 | 
| 1.0.5 | 850 | 4/21/2022 | 
| 1.0.4 | 793 | 4/19/2022 | 
| 1.0.3 | 781 | 4/12/2022 | 
| 1.0.1 | 789 | 4/8/2022 | 
| 1.0.0 | 919 | 4/5/2022 | 
v1.0.14
     * Improved MenuBar undo and fixed stability issues
     * Deleting the last item on a MenuBar now removes the MenuBar too
     * Added multi copy/paste (drag selection box and copy/paste).  Still restricted to non container views (i.e. not TabView etc)
    v1.0.13
     * Changing LineView Orientation now properly flips rune and Width/Height
     * Fixed mouse drag moving and resizing container views (e.g. TabView)
     * Fixed bug where you were able to copy/paste the root view
    v1.0.12
     * Fixed bug multi selections including tab views
    v1.0.11
     * Multi select support for delete and keyboard move
     * Prevent Copy/Paste on root view
     * Prevent changing Height on Buttons
     * Added nuget icon
    v1.0.10
     * Support for setting shortcuts in menus (defaults to Ctrl+T)
     * Support for renaming menu items (defaults to Ctrl+R)
     * Delete added to view context menu
     * Blank values in Pos/Dim editor (e.g. Margin size) are now treated as 0
    v1.0.9
     * Support for adding menu separators by typing '---'
     * Prevent deleting when another view has a RelativeTo specified on it
     * Warn when overwritting a file when creating a new View
     * Replaced generic code comments in files generated to indicate the tool and version used
     * Added copy and paste of single views
     * Support for dragging a control into a seperate container (e.g. into a tab view)
     * Prevent illegal field `(Name)` values being entered
     * Fixed bad code being generated if multiple tables/tab views had columns/tabs with the same name
    v1.0.8
     * Fixed bug free typing new titles for checkboxes
     * Fixed bug free typing new titles dropping last character typed
     * Added keybinding (defaults to Enter) for opening context menu
     * Changed context menu title from 'Properties' to the fieldname of the control being edited
    v1.0.7
     * Support for editing MenuBars
    v1.0.6
     * Fixed bug adding Views to newly created TabViews
     * Fixed undo for operations performed via context menus
     * Added Try/Catch to context menu operations
     * Added support for TreeView
     * Changed TableView example data to be all nulls
	v1.0.5
	 * Right click context menu support
	 * Increased mouse resizing click hit box
	 * Added progress indicator for creating new Views
	 * Fixed mouse dragging/resizing of views in subviews (e.g. TabViews)