mirror of
				https://github.com/spectreconsole/spectre.console.git
				synced 2025-10-25 15:19:23 +00:00 
			
		
		
		
	Add documentation for tables
Also moves "Colors" and "Styles" sections to appendix.
This commit is contained in:
		
				
					committed by
					
						 Patrik Svensson
						Patrik Svensson
					
				
			
			
				
	
			
			
			
						parent
						
							3e9796849b
						
					
				
				
					commit
					003e15686f
				
			| @@ -1,5 +1,5 @@ | |||||||
| Title: Colors | Title: Colors | ||||||
| Order: 4 | Order: 0 | ||||||
| --- | --- | ||||||
| 
 | 
 | ||||||
| The following is a list of the standard 8-bit colors supported in terminals. | The following is a list of the standard 8-bit colors supported in terminals. | ||||||
							
								
								
									
										3
									
								
								docs/input/appendix/index.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								docs/input/appendix/index.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | |||||||
|  | Title: Appendix | ||||||
|  | Order: 10 | ||||||
|  | --- | ||||||
							
								
								
									
										44
									
								
								docs/input/appendix/styles.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								docs/input/appendix/styles.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,44 @@ | |||||||
|  | Title: Styles | ||||||
|  | Order: 0 | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | Note that what styles that can be used is defined by the system or your terminal software, and may not appear as they should. | ||||||
|  |  | ||||||
|  | <table class="table"> | ||||||
|  |     <tr> | ||||||
|  |         <td><code>bold</code></td> | ||||||
|  |         <td>Bold text</td> | ||||||
|  |     </tr> | ||||||
|  |     <tr> | ||||||
|  |         <td><code>dim</code></td> | ||||||
|  |         <td>Dim or faint text</td> | ||||||
|  |     </tr> | ||||||
|  |     <tr> | ||||||
|  |         <td><code>italic</code></td> | ||||||
|  |         <td>Italic text</td> | ||||||
|  |     </tr> | ||||||
|  |     <tr> | ||||||
|  |         <td><code>underline</code></td> | ||||||
|  |         <td>Underlined text</td> | ||||||
|  |     </tr> | ||||||
|  |     <tr> | ||||||
|  |         <td><code>invert</code></td> | ||||||
|  |         <td>Swaps the foreground and background colors</td> | ||||||
|  |     </tr> | ||||||
|  |     <tr> | ||||||
|  |         <td><code>conceal</code></td> | ||||||
|  |         <td>Hides the text</td> | ||||||
|  |     </tr> | ||||||
|  |     <tr> | ||||||
|  |         <td><code>slowblink</code></td> | ||||||
|  |         <td>Makes text blink slowly</td> | ||||||
|  |     </tr> | ||||||
|  |     <tr> | ||||||
|  |         <td><code>rapidblink</code></td> | ||||||
|  |         <td>Makes text blink</td> | ||||||
|  |     </tr> | ||||||
|  |     <tr> | ||||||
|  |         <td><code>strikethrough</code></td> | ||||||
|  |         <td>Shows text with a horizontal line through the center</td> | ||||||
|  |     </tr> | ||||||
|  | </table> | ||||||
							
								
								
									
										
											BIN
										
									
								
								docs/input/assets/images/table.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								docs/input/assets/images/table.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 55 KiB | 
| @@ -1,21 +1,19 @@ | |||||||
| Title: Markup | Title: Markup | ||||||
| Order: 3 | Order: 2 | ||||||
| Hidden: False |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| In `Spectre.Console` there's a class called `Markup` that | In `Spectre.Console` there's a class called `Markup` that | ||||||
| allows you to output rich text to the console. | allows you to output rich text to the console. | ||||||
|  |  | ||||||
|  | # Syntax | ||||||
|  |  | ||||||
|  | Console markup uses a syntax inspired by bbcode. If you write the style (see Styles)  | ||||||
|  | in square brackets, e.g. `[bold red]`, that style will apply until it is closed with a `[/]`. | ||||||
|  |  | ||||||
| ```csharp | ```csharp | ||||||
| AnsiConsole.Render(new Markup("[bold yellow]Hello[/] [red]World![/]")); | AnsiConsole.Render(new Markup("[bold yellow]Hello[/] [red]World![/]")); | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Which should output something similar to the image below. Note that the |  | ||||||
| actual appearance might vary depending on your terminal. |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| The `Markup` class implements `IRenderable` which means that you  | The `Markup` class implements `IRenderable` which means that you  | ||||||
| can use this in tables, grids, and panels. Most classes that support | can use this in tables, grids, and panels. Most classes that support | ||||||
| rendering of `IRenderable` also have overloads for rendering rich text. | rendering of `IRenderable` also have overloads for rendering rich text. | ||||||
| @@ -58,47 +56,8 @@ You can set the background color in markup by prefixing the color with | |||||||
|  |  | ||||||
| # Colors | # Colors | ||||||
|  |  | ||||||
| For a list of colors, see the [Colors](xref:colors) section. | For a list of colors, see the [Colors](xref:colors) appendix section. | ||||||
|  |  | ||||||
| # Styles | # Styles | ||||||
|  |  | ||||||
| Note that what styles that can be used is defined by the system or your terminal software, and may not appear as they should. | For a list of styles, see the [Styles](xref:styles) appendix section. | ||||||
|  |  | ||||||
| <table class="table"> |  | ||||||
|     <tr> |  | ||||||
|         <td><code>bold</code></td> |  | ||||||
|         <td>Bold text</td> |  | ||||||
|     </tr> |  | ||||||
|     <tr> |  | ||||||
|         <td><code>dim</code></td> |  | ||||||
|         <td>Dim or faint text</td> |  | ||||||
|     </tr> |  | ||||||
|     <tr> |  | ||||||
|         <td><code>italic</code></td> |  | ||||||
|         <td>Italic text</td> |  | ||||||
|     </tr> |  | ||||||
|     <tr> |  | ||||||
|         <td><code>underline</code></td> |  | ||||||
|         <td>Underlined text</td> |  | ||||||
|     </tr> |  | ||||||
|     <tr> |  | ||||||
|         <td><code>invert</code></td> |  | ||||||
|         <td>Swaps the foreground and background colors</td> |  | ||||||
|     </tr> |  | ||||||
|     <tr> |  | ||||||
|         <td><code>conceal</code></td> |  | ||||||
|         <td>Hides the text</td> |  | ||||||
|     </tr> |  | ||||||
|     <tr> |  | ||||||
|         <td><code>slowblink</code></td> |  | ||||||
|         <td>Makes text blink slowly</td> |  | ||||||
|     </tr> |  | ||||||
|     <tr> |  | ||||||
|         <td><code>rapidblink</code></td> |  | ||||||
|         <td>Makes text blink</td> |  | ||||||
|     </tr> |  | ||||||
|     <tr> |  | ||||||
|         <td><code>strikethrough</code></td> |  | ||||||
|         <td>Shows text with a horizontal line through the center</td> |  | ||||||
|     </tr> |  | ||||||
| </table> |  | ||||||
							
								
								
									
										118
									
								
								docs/input/tables.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										118
									
								
								docs/input/tables.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,118 @@ | |||||||
|  | Title: Tables | ||||||
|  | Order: 3 | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | Tables are a perfect way of displaying tabular data in a terminal. | ||||||
|  |  | ||||||
|  | `Spectre.Console` is super smart about rendering tables and will adjust | ||||||
|  | all columns to fit whatever is inside them. Anything that implements  | ||||||
|  | `IRenderable` can be used as a column header or column cell, even another table! | ||||||
|  |  | ||||||
|  | # Usage | ||||||
|  |  | ||||||
|  | <!-------------------------> | ||||||
|  | <!--- USAGE             ---> | ||||||
|  | <!-------------------------> | ||||||
|  |  | ||||||
|  | To render a table, create a `Table` instance, add the number of | ||||||
|  | columns that you need, and then add the rows. Finish by passing the | ||||||
|  | table to a console's `Render` method. | ||||||
|  |  | ||||||
|  | ```csharp | ||||||
|  | // Create a table | ||||||
|  | var table = new Table(); | ||||||
|  |  | ||||||
|  | // Add some columns | ||||||
|  | table.AddColumn("Foo"); | ||||||
|  | table.AddColumn(new TableColumn("Bar").Centered()); | ||||||
|  |  | ||||||
|  | // Add some rows | ||||||
|  | table.AddRow("Baz", "[green]Qux[/]"); | ||||||
|  | table.AddRow(new Markup("[blue]Corgi[/]"), new Panel("Waldo")); | ||||||
|  |  | ||||||
|  | // Render the table to the console | ||||||
|  | AnsiConsole.Render(table); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | This will render the following output: | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | # Table appearance | ||||||
|  |  | ||||||
|  | <!-------------------------> | ||||||
|  | <!--- TABLE APPEARANCE  ---> | ||||||
|  | <!-------------------------> | ||||||
|  |  | ||||||
|  | ## Borders | ||||||
|  |  | ||||||
|  | ```csharp | ||||||
|  | // Sets the border kind | ||||||
|  | table.SetBorderKind(BorderKind.None); | ||||||
|  | table.SetBorderKind(BorderKind.Ascii); | ||||||
|  | table.SetBorderKind(BorderKind.Square); | ||||||
|  | table.SetBorderKind(BorderKind.Rounded); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Expand / Collapse | ||||||
|  |  | ||||||
|  | ```csharp | ||||||
|  | // Table will take up as much space as it can | ||||||
|  | // with respect to other things. | ||||||
|  | table.Expand(); | ||||||
|  |  | ||||||
|  | // Table will take up minimal width | ||||||
|  | table.Collapse(); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Hide headers | ||||||
|  |  | ||||||
|  | ```csharp | ||||||
|  | // Hides all column headers | ||||||
|  | table.HideHeaders(); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Set table width | ||||||
|  |  | ||||||
|  | ```csharp | ||||||
|  | // Sets the table width to 50 cells | ||||||
|  | table.SetWidth(50); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | # Column appearance | ||||||
|  |  | ||||||
|  | <!-------------------------> | ||||||
|  | <!--- COLUMN APPEARANCE ---> | ||||||
|  | <!-------------------------> | ||||||
|  |  | ||||||
|  | ## Alignment | ||||||
|  |  | ||||||
|  | ```csharp | ||||||
|  | // Set the alignment explicitly | ||||||
|  | column.SetAlignment(Justify.Right); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Padding | ||||||
|  |  | ||||||
|  | ```csharp | ||||||
|  | // Set left and right padding | ||||||
|  | column.SetPadding(left: 3, right: 5); | ||||||
|  |  | ||||||
|  | // Set padding individually. | ||||||
|  | column.PadLeft(3); | ||||||
|  | column.PadRight(5); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Disable column wrapping | ||||||
|  |  | ||||||
|  | ```csharp | ||||||
|  | // Disable column wrapping | ||||||
|  | column.NoWrap(); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Set column width | ||||||
|  |  | ||||||
|  | ```csharp | ||||||
|  | // Set the column width (no fluent extension method for this yet) | ||||||
|  | column.Width = 15; | ||||||
|  | ``` | ||||||
		Reference in New Issue
	
	Block a user