batgrl.gadgets.data_table#
A data table gadget.
Classes
|
Style of a column in a data table. |
|
A data table gadget. |
|
Supports the less than (<) operator. |
|
Base for cells in a data table. |
|
A column label cell in a data table. |
|
A data cell in a data table. |
|
|
|
Sorted state of a column in a data table. |
- class batgrl.gadgets.data_table.ColumnStyle(render: Callable[[T], str] | None = None, alignment: Literal['center', 'left', 'right'] = 'left', padding: int = 1, min_width: int = 0, allow_sorting: bool = True)#
Bases:
object
Style of a column in a data table. Includes how data is rendered, alignment, padding, and minimum width.
- Parameters:
- renderCallable[[T], str] | None, default: None
A callable that renders column data into a string. Uses the built-in str by default.
- alignmentLiteral[“center”, “left”, “right”], default: “left”
Alignment of the column.
- paddingint, default: 1
Left and right padding of column.
- min_widthint, default: 0
Minimum width of column.
- allow_sortingbool, default: True
Whether sorting is allowed for column.
- Attributes:
- renderCallable[[T], str]
A callable that renders column data into a string.
- alignmentLiteral[“center”, “left”, “right”]
Alignment of the column.
- paddingint
Left and right padding of column.
- min_widthint
Minimum width of column.
- allow_sortingbool
Whether sorting is allowed for column.
- alignment: Literal['center', 'left', 'right'] = 'left'#
Alignment of the column.
- allow_sorting: bool = True#
Whether sorting is allowed for column.
- min_width: int = 0#
Minimum width of column.
- padding: int = 1#
Left and right padding of column.
- render: Callable[[T], str] | None = None#
A callable that renders column data into a string. Uses the built-in str by default.
- class batgrl.gadgets.data_table.DataTable(*, data: dict[str, Sequence[T]] | None = None, default_style: ColumnStyle | None = None, select_items: Literal['cell', 'row', 'column'] = 'row', zebra_stripes: bool = True, allow_sorting: bool = True, alpha: float = 1.0, size: Size = (10, 10), pos: Point = (0, 0), size_hint: SizeHint | None = None, pos_hint: PosHint | None = None, is_transparent: bool = False, is_visible: bool = True, is_enabled: bool = True)#
-
A data table gadget.
- Parameters:
- datadict[str, Sequence[T]] | None=None, default: None
If given, construct a data table from this data. To gain more control over column styling use
add_column()
.- default_styleColumnStyle | None, default: None
Default style for new columns.
- select_itemsLiteral[“cell”, “row”, “column”], default: “row”
Determines which items are selected when data table is clicked.
- zebra_stripesbool, default: True
Whether alternate rows are colored differently.
- allow_sortingbool, default: True
Whether columns can be sorted.
- alphafloat, default: 1.0
Transparency of gadget.
- sizeSize, default: Size(10, 10)
Size of gadget.
- posPoint, default: Point(0, 0)
Position of upper-left corner in parent.
- size_hintSizeHint | None, default: None
Size as a proportion of parent’s height and width.
- pos_hintPosHint | None, default: None
Position as a proportion of parent’s height and width.
- is_transparentbool, default: False
Whether gadget is transparent.
- is_visiblebool, default: True
Whether gadget is visible. Gadget will still receive input events if not visible.
- is_enabledbool, default: True
Whether gadget is enabled. A disabled gadget is not painted and doesn’t receive input events.
- Attributes:
- default_styleColumnStyle
Default style for new columns.
select_items
Literal[“cell”, “row”, “column”]Determines which items are selected when data table is clicked.
zebra_stripes
boolWhether alternate rows are colored differently.
allow_sorting
boolWhether columns can be sorted.
alpha
floatTransparency of gadget.
size
SizeSize of gadget.
height
intHeight of gadget.
rows
intHeight of gadget.
width
intWidth of gadget.
columns
intWidth of gadget.
pos
PointPosition relative to parent.
top
inty-coordinate of top of gadget.
y
inty-coordinate of top of gadget.
left
intx-coordinate of left side of gadget.
x
intx-coordinate of left side of gadget.
bottom
inty-coordinate of bottom of gadget.
right
intx-coordinate of right side of gadget.
center
PointPosition of center of gadget.
absolute_pos
PointAbsolute position on screen.
size_hint
SizeHintGadget’s size as a proportion of its parent’s size.
pos_hint
PosHintGadget’s position as a proportion of its parent’s size.
- parent: Gadget | None
Parent gadget.
- childrenlist[Gadget]
Children gadgets.
is_transparent
boolWhether gadget is transparent.
is_visible
boolWhether gadget is visible.
is_enabled
boolWhether gadget is enabled.
root
Gadget | NoneReturn the root gadget if connected to gadget tree.
app
AppThe running app.
Methods
add_column(label, …)
Add a column to the data table.
add_row(data)
Add a row to the data table.
remove_column(column_id)
Remove a column by column id.
remove_row(row_id)
Remove a row by row id.
row_id_from_index(index)
Returns the row id of the row at index.
column_id_from_index(index)
Returns the column id of the column at index.
update_theme()
Paint the gadget with current theme.
apply_hints()
Apply size and pos hints.
to_local(point)
Convert point in absolute coordinates to local coordinates.
collides_point(point)
Return true if point collides with visible portion of gadget.
collides_gadget(other)
Return true if other is within gadget’s bounding box.
pull_to_front()
Move to end of gadget stack so gadget is drawn last.
walk()
Yield all descendents of this gadget (preorder traversal).
walk_reverse()
Yield all descendents of this gadget (reverse postorder traversal).
ancestors()
Yield all ancestors of this gadget.
add_gadget(gadget)
Add a child gadget.
add_gadgets(*gadgets)
Add multiple child gadgets.
remove_gadget(gadget)
Remove a child gadget.
prolicide()
Recursively remove all children.
destroy()
Remove this gadget and recursively remove all its children.
bind(prop, callback)
Bind callback to a gadget property.
unbind(uid)
Unbind a callback from a gadget property.
tween(…)
Sequentially update gadget properties over time.
on_size()
Update gadget after a resize.
on_transparency()
Update gadget after transparency is enabled/disabled.
on_add()
Update gadget after being added to the gadget tree.
on_remove()
Update gadget after being removed from the gadget tree.
on_key(key_event)
Handle a key press event.
on_mouse(mouse_event)
Handle a mouse event.
on_paste(paste_event)
Handle a paste event.
on_terminal_focus(focus_event)
Handle a focus event.
- add_column(label: str, data: Sequence[T] | None = None, style: ColumnStyle | None = None) int #
Add a column to the data table.
If this is the first column added to the table, a row will be added for each item in data. Otherwise, the number of items in data must be equal to the number of rows in the table.
- Parameters:
- labelstr
The column label.
- dataSequence[T] | None, default: None
Column data.
- styleColumnStyle | None, default: None
Column style. Uses
default_style
by default.
- Returns:
- int
Column id. This id can be used to remove the column.
- add_gadget(gadget: Self) None #
Add a child gadget.
- Parameters:
- gadgetGadget
A gadget to add as a child.
- add_gadgets(*gadgets: Self) None #
Add multiple child gadgets.
- Parameters:
- *gadgetsGadget
Gadgets to add as children. Can also accept a single iterable of gadgets.
- add_row(data: Sequence[SupportsLessThan]) int #
Add a row to the data table.
There must be at least one column before a row can be added. The number of items in the row must match the number of columns.
- Parameters:
- dataSequence[SupportsLessThan]
The row data.
- Returns:
- int
Row id. This id can be used to remove the row.
- property allow_sorting: bool#
Whether columns can be sorted.
- property alpha: float#
Transparency of gadget.
- ancestors() Iterator[Self] #
Yield all ancestors of this gadget.
- Yields:
- Gadget
An ancestor of this gadget.
- property app#
The running app.
- apply_hints() None #
Apply size and pos hints.
This is called automatically when the gadget is added to the gadget tree and when the gadget’s parent’s size changes.
- bind(prop: str, callback: Callable[[], None]) int #
Bind callback to a gadget property. When the property is updated, callback is called with no arguments.
- Parameters:
- propstr
The name of the gadget property.
- callbackCallable[[], None]
Callback to bind to property.
- Returns:
- int
A unique id used to unbind the callback.
- property bottom: int#
y-coordinate of bottom of gadget.
- children: _GadgetList#
The gadget’s children.
- collides_gadget(other: Self) bool #
Return true if other is within gadget’s bounding box.
- Parameters:
- otherGadget
Another gadget.
- Returns:
- bool
Whether other collides with gadget.
- collides_point(point: Point) bool #
Return true if point collides with visible portion of gadget.
- Parameters:
- pointPoint
A point.
- Returns:
- bool
Whether point collides with gadget.
- color_theme: _ColorTheme#
- column_id_from_index(index: int) int #
Return the column id of the column at index.
- Parameters:
- indexint
Index of column in table.
- Returns:
- int
Column id of the column at index.
- property columns: int#
Width of gadget.
- default_style#
Default style for new columns.
- destroy() None #
Remove this gadget and recursively remove all its children.
- dispatch_key(key_event: KeyEvent) bool | None #
Dispatch a key press event until handled.
A key press event is handled if a handler returns
True
.- Parameters:
- key_eventKeyEvent
The key event to dispatch.
- Returns:
- bool | None
Whether the dispatch was handled.
- dispatch_mouse(mouse_event: MouseEvent) bool | None #
Dispatch a mouse event until handled.
A mouse event is handled if a handler returns
True
.- Parameters:
- mouse_eventMouseEvent
The mouse event to dispatch.
- Returns:
- bool | None
Whether the dispatch was handled.
- dispatch_paste(paste_event: PasteEvent) bool | None #
Dispatch a paste event until handled.
A paste event is handled if a handler returns
True
.- Parameters:
- paste_eventPasteEvent
The paste event to dispatch.
- Returns:
- bool | None
Whether the dispatch was handled.
- dispatch_terminal_focus(focus_event: FocusEvent) bool | None #
Dispatch a focus event until handled.
A focus event is handled if a handler returns
True
.- Parameters:
- focus_eventFocusEvent
The focus event to dispatch.
- Returns:
- bool | None
Whether the dispatch was handled.
- property height: int#
Height of gadget.
- property is_enabled: bool#
Whether gadget is enabled. A disabled gadget is not painted and doesn’t receive input events.
- property is_transparent: bool#
Whether gadget is transparent.
- property is_visible: bool#
Whether gadget is visible. Gadget will still receive input events if not visible.
- property left: int#
x-coordinate of left side of gadget.
- on_add()#
Update theme.
- on_key(key_event: KeyEvent) bool | None #
Handle a key press event.
Handled key presses should return
True
.- Parameters:
- key_eventKeyEvent
The key event to handle.
- Returns:
- bool | None
Whether the key event was handled.
- on_mouse(mouse_event: MouseEvent) bool | None #
Highlight row on mouse collision.
- on_paste(paste_event: PasteEvent) bool | None #
Handle a paste event.
Handled paste events should return
True
.- Parameters:
- paste_eventPasteEvent
The paste event to handle.
- Returns:
- bool | None
Whether the paste event was handled.
- on_remove() None #
Update gadget after being removed from the gadget tree.
- on_size() None #
Update gadget after a resize.
- on_terminal_focus(focus_event: FocusEvent) bool | None #
Handle a focus event.
Handled focus events should return
True
.- Parameters:
- focus_eventFocusEvent
The focus event to handle.
- Returns:
- bool | None
Whether the focus event was handled.
- on_transparency() None #
Update gadget after transparency is enabled/disabled.
- prolicide() None #
Recursively remove all children.
- pull_to_front() None #
Move gadget to end of gadget stack so that it is drawn last.
- remove_column(column_id: int)#
Remove a column by column id.
Column id can be retrieved by index with
column_id_from_index()
.- Parameters:
- column_idint
The id of the column to remove.
- remove_gadget(gadget: Self) None #
Remove a child gadget.
- Parameters:
- gadgetGadget
The gadget to remove from children.
- remove_row(row_id: int)#
Remove a row by row id.
Row id can be retrieved by index with
row_id_from_index()
.- Parameters:
- row_idint
The id of the row to remove.
- property right: int#
x-coordinate of right side of gadget.
- property root: Self | None#
Return the root gadget if connected to gadget tree.
- row_id_from_index(index: int) int #
Return the row id of the row at index.
- Parameters:
- indexint
Index of row in table.
- Returns:
- int
Row id of the row tat index.
- property rows: int#
Height of gadget.
- property select_items: Literal['cell', 'row', 'column']#
Determines which items are selected when data table is clicked.
- classmethod set_theme(color_theme: ColorTheme)#
Set color theme.
- to_local(point: Point) Point #
Convert point in absolute coordinates to local coordinates.
- Parameters:
- pointPoint
Point in absolute (screen) coordinates.
- Returns:
- Point
The point in local coordinates.
- property top: int#
y-coordinate of top of gadget.
- async tween(*, duration: float = 1.0, easing: Literal['linear', 'in_quad', 'out_quad', 'in_out_quad', 'in_cubic', 'out_cubic', 'in_out_cubic', 'in_quart', 'out_quart', 'in_out_quart', 'in_quint', 'out_quint', 'in_out_quint', 'in_sine', 'out_sine', 'in_out_sine', 'in_exp', 'out_exp', 'in_out_exp', 'in_circ', 'out_circ', 'in_out_circ', 'in_elastic', 'out_elastic', 'in_out_elastic', 'in_back', 'out_back', 'in_out_back', 'in_bounce', 'out_bounce', 'in_out_bounce'] = 'linear', on_start: Callable[[], None] | None = None, on_progress: Callable[[float], None] | None = None, on_complete: Callable[[], None] | None = None, **properties: Real | ndarray[Any, dtype[number]] | Sequence[Real] | PosHint | SizeHint) None #
Coroutine that sequentially updates gadget properties over a duration (in seconds).
- Parameters:
- durationfloat, default: 1.0
The duration of the tween in seconds.
- easingEasing, default: “linear”
The easing used for tweening.
- on_startCallable[[], None] | None, default: None
Called when tween starts.
- on_progressCallable[[float], None] | None, default: None
Called as tween updates with current progress.
- on_completeCallable[[], None] | None, default: None
Called when tween completes.
- **propertiesReal | NDArray[np.number] | Sequence[Real] | PosHint | SizeHint
Gadget properties’ target values. E.g., to smoothly tween a gadget’s position to (5, 10) over 2.5 seconds, specify the pos property as a keyword-argument:
await gadget.tween(pos=(5, 10), duration=2.5, easing="out_bounce")
Warning
Running several tweens on the same properties concurrently will probably result in unexpected behavior.
Notes
Tweened values will be coerced to match the type of the initial value of their corresponding property.
Non-numeric values will be set immediately.
- unbind(uid: int) None #
Unbind a callback from a gadget property.
- Parameters:
- uidint
Unique id returned by the
bind()
method.
- update_theme()#
Paint the gadget with current theme.
- walk() Iterator[Self] #
Yield all descendents of this gadget (preorder traversal).
- Yields:
- Gadget
A descendent of this gadget.
- walk_reverse() Iterator[Self] #
Yield all descendents of this gadget (reverse postorder traversal).
- Yields:
- Gadget
A descendent of this gadget.
- property width: int#
Width of gadget.
- property x: int#
x-coordinate of left side of gadget.
- property y: int#
y-coordinate of top of gadget.
- property zebra_stripes: bool#
Whether alternate rows are colored differently.
- class batgrl.gadgets.data_table.SupportsLessThan(*args, **kwargs)#
Bases:
Protocol
Supports the less than (<) operator.