| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
 100
 101
 102
 103
 104
 105
 106
 107
 108
 109
 110
 111
 112
 113
 114
 115
 116
 117
 118
 119
 120
 121
 122
 123
 124
 125
 
 | # Sparkline
!!! tip "Added in version 0.27.0"
A widget that is used to visually represent numerical data.
- [ ] Focusable
- [ ] Container
## Examples
### Basic example
The example below illustrates the relationship between the data, its length, the width of the sparkline, and the number of bars displayed.
!!! tip
    The sparkline data is split into equally-sized chunks.
    Each chunk is represented by a bar and the width of the sparkline dictates how many bars there are.
=== "Output"
    ```{.textual path="docs/examples/widgets/sparkline_basic.py" lines="5" columns="30"}
    ```
=== "sparkline_basic.py"
    ```python hl_lines="4 11 12 13"
    --8<-- "docs/examples/widgets/sparkline_basic.py"
    ```
    1. We have 12 data points.
    2. This sparkline will have its width set to 3 via CSS.
    3. The data (12 numbers) will be split across 3 bars, so 4 data points are associated with each bar.
    4. Each bar will represent its largest value.
    The largest value of each chunk is 2, 4, and 8, respectively.
    That explains why the first bar is half the height of the second and the second bar is half the height of the third.
=== "sparkline_basic.tcss"
    ```css
    --8<-- "docs/examples/widgets/sparkline_basic.tcss"
    ```
    1. By setting the width to 3 we get three buckets.
### Different summary functions
The example below shows a sparkline widget with different summary functions.
The summary function is what determines the height of each bar.
=== "Output"
    ```{.textual path="docs/examples/widgets/sparkline.py" lines="11"}
    ```
=== "sparkline.py"
    ```python hl_lines="15-17"
    --8<-- "docs/examples/widgets/sparkline.py"
    ```
    1. Each bar will show the largest value of that bucket.
    2. Each bar will show the mean value of that bucket.
    3. Each bar will show the smaller value of that bucket.
=== "sparkline.tcss"
    ```css
    --8<-- "docs/examples/widgets/sparkline.tcss"
    ```
### Changing the colors
The example below shows how to use component classes to change the colors of the sparkline.
=== "Output"
    ```{.textual path="docs/examples/widgets/sparkline_colors.py" lines=22}
    ```
=== "sparkline_colors.py"
    ```python
    --8<-- "docs/examples/widgets/sparkline_colors.py"
    ```
=== "sparkline_colors.tcss"
    ```css
    --8<-- "docs/examples/widgets/sparkline_colors.tcss"
    ```
## Reactive Attributes
| Name      | Type  | Default     | Description                                        |
| --------- | ----- | ----------- | -------------------------------------------------- |
| `data` | `Sequence[float] | None` | `None` | The data represented by the sparkline. |
| `summary_function` | `Callable[[Sequence[float]], float]` | `max` | The function that computes the height of each bar. |
## Messages
This widget posts no messages.
## Bindings
This widget has no bindings.
## Component Classes
The sparkline widget provides the following component classes:
::: textual.widgets.Sparkline.COMPONENT_CLASSES
    options:
      show_root_heading: false
      show_root_toc_entry: false
---
::: textual.widgets.Sparkline
    options:
      heading_level: 2
 |