Entry#

class Entry(**properties: Any)#

Superclasses: Widget, InitiallyUnowned, Object

Implemented Interfaces: Accessible, Buildable, CellEditable, ConstraintTarget, Editable

GtkEntry is a single line text entry widget.

https://docs.gtk.org/gtk4/entry.png

A fairly large set of key bindings are supported by default. If the entered text is longer than the allocation of the widget, the widget will scroll so that the cursor position is visible.

When using an entry for passwords and other sensitive information, it can be put into “password mode” using set_visibility. In this mode, entered text is displayed using a “invisible” character. By default, GTK picks the best invisible character that is available in the current font, but it can be changed with set_invisible_char.

GtkEntry has the ability to display progress or activity information behind the text. To make an entry display such information, use set_progress_fraction or set_progress_pulse_step.

Additionally, GtkEntry can show icons at either side of the entry. These icons can be activatable by clicking, can be set up as drag source and can have tooltips. To add an icon, use set_icon_from_gicon or one of the various other functions that set an icon from an icon name or a paintable. To trigger an action when the user clicks an icon, connect to the icon_press signal. To allow DND operations from an icon, use set_icon_drag_source. To set a tooltip on an icon, use set_icon_tooltip_text or the corresponding function for markup.

Note that functionality or information that is only available by clicking on an icon in an entry may not be accessible at all to users which are not able to use a mouse or other pointing device. It is therefore recommended that any such functionality should also be available by other means, e.g. via the context menu of the entry.

CSS nodes#

entry[.flat][.warning][.error]
├── text[.readonly]
├── image.left
├── image.right
╰── [progress[.pulse]]

GtkEntry has a main node with the name entry. Depending on the properties of the entry, the style classes .read-only and .flat may appear. The style classes .warning and .error may also be used with entries.

When the entry shows icons, it adds subnodes with the name image and the style class .left or .right, depending on where the icon appears.

When the entry shows progress, it adds a subnode with the name progress. The node has the style class .pulse when the shown progress is pulsing.

For all the subnodes added to the text node in various situations, see Text.

GtkEntry as GtkBuildable#

The GtkEntry implementation of the GtkBuildable interface supports a custom <attributes> element, which supports any number of <attribute> elements. The <attribute> element has attributes named “name“, “value“, “start“ and “end“ and allows you to specify PangoAttribute values for this label.

An example of a UI definition fragment specifying Pango attributes:

<object class="GtkEntry">
  <attributes>
    <attribute name="weight" value="PANGO_WEIGHT_BOLD"/>
    <attribute name="background" value="red" start="5" end="10"/>
  </attributes>
</object>

The start and end attributes specify the range of characters to which the Pango attribute applies. If start and end are not specified, the attribute is applied to the whole text. Note that specifying ranges does not make much sense with translatable attributes. Use markup embedded in the translatable content instead.

Accessibility#

GtkEntry uses the TEXT_BOX role.

Constructors#

class Entry
classmethod new() Widget#

Creates a new entry.

classmethod new_with_buffer(buffer: EntryBuffer) Widget#

Creates a new entry with the specified text buffer.

Parameters:

buffer – The buffer to use for the new GtkEntry.

Methods#

class Entry
get_activates_default() bool#

Retrieves the value set by set_activates_default().

get_alignment() float#

Gets the value set by set_alignment().

See also: xalign

get_attributes() AttrList | None#

Gets the attribute list of the GtkEntry.

See set_attributes.

get_buffer() EntryBuffer#

Get the GtkEntryBuffer object which holds the text for this widget.

get_completion() EntryCompletion | None#

Returns the auxiliary completion object currently in use by entry.

Deprecated since version 4.10: GtkEntryCompletion will be removed in GTK 5.

get_current_icon_drag_source() int#

Returns the index of the icon which is the source of the current DND operation, or -1.

get_extra_menu() MenuModel | None#

Gets the menu model set with set_extra_menu().

get_has_frame() bool#

Gets the value set by set_has_frame().

get_icon_activatable(icon_pos: EntryIconPosition) bool#

Returns whether the icon is activatable.

Parameters:

icon_pos – Icon position

get_icon_area(icon_pos: EntryIconPosition) Rectangle#

Gets the area where entry’s icon at icon_pos is drawn.

This function is useful when drawing something to the entry in a draw callback.

If the entry is not realized or has no icon at the given position, icon_area is filled with zeros. Otherwise, icon_area will be filled with the icon’s allocation, relative to entry’s allocation.

Parameters:

icon_pos – Icon position

get_icon_at_pos(x: int, y: int) int#

Finds the icon at the given position and return its index.

The position’s coordinates are relative to the entry’s top left corner. If x, y doesn’t lie inside an icon,

-1 is returned. This function is intended for use in a

query_tooltip signal handler.

Parameters:
  • x – the x coordinate of the position to find, relative to entry

  • y – the y coordinate of the position to find, relative to entry

get_icon_gicon(icon_pos: EntryIconPosition) Icon | None#

Retrieves the GIcon used for the icon.

None will be returned if there is no icon or if the icon was set by some other method (e.g., by GdkPaintable or icon name).

Parameters:

icon_pos – Icon position

get_icon_name(icon_pos: EntryIconPosition) str | None#

Retrieves the icon name used for the icon.

None is returned if there is no icon or if the icon was set by some other method (e.g., by GdkPaintable or gicon).

Parameters:

icon_pos – Icon position

get_icon_paintable(icon_pos: EntryIconPosition) Paintable | None#

Retrieves the GdkPaintable used for the icon.

If no GdkPaintable was used for the icon, None is returned.

Parameters:

icon_pos – Icon position

get_icon_sensitive(icon_pos: EntryIconPosition) bool#

Returns whether the icon appears sensitive or insensitive.

Parameters:

icon_pos – Icon position

get_icon_storage_type(icon_pos: EntryIconPosition) ImageType#

Gets the type of representation being used by the icon to store image data.

If the icon has no image data, the return value will be EMPTY.

Parameters:

icon_pos – Icon position

get_icon_tooltip_markup(icon_pos: EntryIconPosition) str | None#

Gets the contents of the tooltip on the icon at the specified position in entry.

Parameters:

icon_pos – the icon position

get_icon_tooltip_text(icon_pos: EntryIconPosition) str | None#

Gets the contents of the tooltip on the icon at the specified position in entry.

Parameters:

icon_pos – the icon position

get_input_hints() InputHints#

Gets the input hints of this GtkEntry.

get_input_purpose() InputPurpose#

Gets the input purpose of the GtkEntry.

get_invisible_char() str#

Retrieves the character displayed in place of the actual text in “password mode”.

get_max_length() int#

Retrieves the maximum allowed length of the text in entry.

See set_max_length.

get_overwrite_mode() bool#

Gets whether the GtkEntry is in overwrite mode.

get_placeholder_text() str | None#

Retrieves the text that will be displayed when entry is empty and unfocused

get_progress_fraction() float#

Returns the current fraction of the task that’s been completed.

See set_progress_fraction.

get_progress_pulse_step() float#

Retrieves the pulse step set with set_progress_pulse_step().

get_tabs() TabArray | None#

Gets the tabstops of the GtkEntry.

See set_tabs.

get_text_length() int#

Retrieves the current length of the text in entry.

This is equivalent to getting entry’s GtkEntryBuffer and calling get_length on it.

get_visibility() bool#

Retrieves whether the text in entry is visible.

See set_visibility.

grab_focus_without_selecting() bool#

Causes entry to have keyboard focus.

It behaves like grab_focus, except that it doesn’t select the contents of the entry. You only want to call this on some special entries which the user usually doesn’t want to replace all text in, such as search-as-you-type entries.

progress_pulse() None#

Indicates that some progress is made, but you don’t know how much.

Causes the entry’s progress indicator to enter “activity mode”, where a block bounces back and forth. Each call to progress_pulse() causes the block to move by a little bit (the amount of movement per pulse is determined by set_progress_pulse_step).

reset_im_context() None#

Reset the input method context of the entry if needed.

This can be necessary in the case where modifying the buffer would confuse on-going input method behavior.

set_activates_default(setting: bool) None#

Sets whether pressing Enter in the entry will activate the default widget for the window containing the entry.

This usually means that the dialog containing the entry will be closed, since the default widget is usually one of the dialog buttons.

Parameters:

settingTrue to activate window’s default widget on Enter keypress

set_alignment(xalign: float) None#

Sets the alignment for the contents of the entry.

This controls the horizontal positioning of the contents when the displayed text is shorter than the width of the entry.

See also: xalign

Parameters:

xalign – The horizontal alignment, from 0 (left) to 1 (right). Reversed for RTL layouts

set_attributes(attrs: AttrList) None#

Sets a PangoAttrList.

The attributes in the list are applied to the entry text.

Since the attributes will be applied to text that changes as the user types, it makes most sense to use attributes with unlimited extent.

Parameters:

attrs – a PangoAttrList

set_buffer(buffer: EntryBuffer) None#

Set the GtkEntryBuffer object which holds the text for this widget.

Parameters:

buffer – a GtkEntryBuffer

set_completion(completion: EntryCompletion | None = None) None#

Sets completion to be the auxiliary completion object to use with entry.

All further configuration of the completion mechanism is done on completion using the GtkEntryCompletion API. Completion is disabled if completion is set to None.

Deprecated since version 4.10: GtkEntryCompletion will be removed in GTK 5.

Parameters:

completion – The GtkEntryCompletion

set_extra_menu(model: MenuModel | None = None) None#

Sets a menu model to add when constructing the context menu for entry.

Parameters:

model – a GMenuModel

set_has_frame(setting: bool) None#

Sets whether the entry has a beveled frame around it.

Parameters:

setting – new value

set_icon_activatable(icon_pos: EntryIconPosition, activatable: bool) None#

Sets whether the icon is activatable.

Parameters:
  • icon_pos – Icon position

  • activatableTrue if the icon should be activatable

set_icon_drag_source(icon_pos: EntryIconPosition, provider: ContentProvider, actions: DragAction) None#

Sets up the icon at the given position as drag source.

This makes it so that GTK will start a drag operation when the user clicks and drags the icon.

Parameters:
  • icon_pos – icon position

  • provider – a GdkContentProvider

  • actions – a bitmask of the allowed drag actions

set_icon_from_gicon(icon_pos: EntryIconPosition, icon: Icon | None = None) None#

Sets the icon shown in the entry at the specified position from the current icon theme.

If the icon isn’t known, a “broken image” icon will be displayed instead.

If icon is None, no icon will be shown in the specified position.

Parameters:
  • icon_pos – The position at which to set the icon

  • icon – The icon to set

set_icon_from_icon_name(icon_pos: EntryIconPosition, icon_name: str | None = None) None#

Sets the icon shown in the entry at the specified position from the current icon theme.

If the icon name isn’t known, a “broken image” icon will be displayed instead.

If icon_name is None, no icon will be shown in the specified position.

Parameters:
  • icon_pos – The position at which to set the icon

  • icon_name – An icon name

set_icon_from_paintable(icon_pos: EntryIconPosition, paintable: Paintable | None = None) None#

Sets the icon shown in the specified position using a GdkPaintable.

If paintable is None, no icon will be shown in the specified position.

Parameters:
  • icon_pos – Icon position

  • paintable – A GdkPaintable

set_icon_sensitive(icon_pos: EntryIconPosition, sensitive: bool) None#

Sets the sensitivity for the specified icon.

Parameters:
  • icon_pos – Icon position

  • sensitive – Specifies whether the icon should appear sensitive or insensitive

set_icon_tooltip_markup(icon_pos: EntryIconPosition, tooltip: str | None = None) None#

Sets tooltip as the contents of the tooltip for the icon at the specified position.

tooltip is assumed to be marked up with Pango Markup.

Use None for tooltip to remove an existing tooltip.

See also set_tooltip_markup and set_icon_tooltip_text.

Parameters:
  • icon_pos – the icon position

  • tooltip – the contents of the tooltip for the icon

set_icon_tooltip_text(icon_pos: EntryIconPosition, tooltip: str | None = None) None#

Sets tooltip as the contents of the tooltip for the icon at the specified position.

Use None for tooltip to remove an existing tooltip.

See also set_tooltip_text and set_icon_tooltip_markup.

If you unset the widget tooltip via set_tooltip_text or set_tooltip_markup, this sets has_tooltip to False, which suppresses icon tooltips too. You can resolve this by then calling set_has_tooltip to set has_tooltip back to True, or setting at least one non-empty tooltip on any icon achieves the same result.

Parameters:
  • icon_pos – the icon position

  • tooltip – the contents of the tooltip for the icon

set_input_hints(hints: InputHints) None#

Set additional hints which allow input methods to fine-tune their behavior.

Parameters:

hints – the hints

set_input_purpose(purpose: InputPurpose) None#

Sets the input purpose which can be used by input methods to adjust their behavior.

Parameters:

purpose – the purpose

set_invisible_char(ch: str) None#

Sets the character to use in place of the actual text in “password mode”.

See set_visibility for how to enable “password mode”.

By default, GTK picks the best invisible char available in the current font. If you set the invisible char to 0, then the user will get no feedback at all; there will be no text on the screen as they type.

Parameters:

ch – a Unicode character

set_max_length(max: int) None#

Sets the maximum allowed length of the contents of the widget.

If the current contents are longer than the given length, then they will be truncated to fit. The length is in characters.

This is equivalent to getting entry’s GtkEntryBuffer and calling set_max_length on it.

Parameters:

max – the maximum length of the entry, or 0 for no maximum. (other than the maximum length of entries.) The value passed in will be clamped to the range 0-65536.

set_overwrite_mode(overwrite: bool) None#

Sets whether the text is overwritten when typing in the GtkEntry.

Parameters:

overwrite – new value

set_placeholder_text(text: str | None = None) None#

Sets text to be displayed in entry when it is empty.

This can be used to give a visual hint of the expected contents of the GtkEntry.

Parameters:

text – a string to be displayed when entry is empty and unfocused

set_progress_fraction(fraction: float) None#

Causes the entry’s progress indicator to “fill in” the given fraction of the bar.

The fraction should be between 0.0 and 1.0, inclusive.

Parameters:

fraction – fraction of the task that’s been completed

set_progress_pulse_step(fraction: float) None#

Sets the fraction of total entry width to move the progress bouncing block for each pulse.

Use progress_pulse to pulse the progress.

Parameters:

fraction – fraction between 0.0 and 1.0

set_tabs(tabs: TabArray | None = None) None#

Sets a PangoTabArray.

The tabstops in the array are applied to the entry text.

Parameters:

tabs – a PangoTabArray

set_visibility(visible: bool) None#

Sets whether the contents of the entry are visible or not.

When visibility is set to False, characters are displayed as the invisible char, and will also appear that way when the text in the entry widget is copied elsewhere.

By default, GTK picks the best invisible character available in the current font, but it can be changed with set_invisible_char.

Note that you probably want to set input_purpose to PASSWORD or PIN to inform input methods about the purpose of this entry, in addition to setting visibility to False.

Parameters:

visibleTrue if the contents of the entry are displayed as plaintext

unset_invisible_char() None#

Unsets the invisible char, so that the default invisible char is used again. See set_invisible_char.

Properties#

class Entry
props.activates_default: bool#

The type of the None singleton.

props.attributes: AttrList#

The type of the None singleton.

props.buffer: EntryBuffer#

The type of the None singleton.

props.completion: EntryCompletion#

The type of the None singleton.

Deprecated since version 4.10: GtkEntryCompletion will be removed in GTK 5.

props.enable_emoji_completion: bool#

The type of the None singleton.

props.extra_menu: MenuModel#

The type of the None singleton.

props.has_frame: bool#

The type of the None singleton.

props.im_module: str#

The type of the None singleton.

props.input_hints: InputHints#

The type of the None singleton.

props.input_purpose: InputPurpose#

The type of the None singleton.

props.invisible_char: int#

The type of the None singleton.

props.invisible_char_set: bool#

The type of the None singleton.

props.max_length: int#

The type of the None singleton.

props.overwrite_mode: bool#

The type of the None singleton.

props.placeholder_text: str#

The type of the None singleton.

props.primary_icon_activatable: bool#

The type of the None singleton.

props.primary_icon_gicon: Icon#

The type of the None singleton.

props.primary_icon_name: str#

The type of the None singleton.

props.primary_icon_paintable: Paintable#

The type of the None singleton.

props.primary_icon_sensitive: bool#

The type of the None singleton.

props.primary_icon_storage_type: ImageType#

The type of the None singleton.

props.primary_icon_tooltip_markup: str#

The type of the None singleton.

props.primary_icon_tooltip_text: str#

The type of the None singleton.

props.progress_fraction: float#

The type of the None singleton.

props.progress_pulse_step: float#

The type of the None singleton.

props.scroll_offset: int#

The type of the None singleton.

props.secondary_icon_activatable: bool#

The type of the None singleton.

props.secondary_icon_gicon: Icon#

The type of the None singleton.

props.secondary_icon_name: str#

The type of the None singleton.

props.secondary_icon_paintable: Paintable#

The type of the None singleton.

props.secondary_icon_sensitive: bool#

The type of the None singleton.

props.secondary_icon_storage_type: ImageType#

The type of the None singleton.

props.secondary_icon_tooltip_markup: str#

The type of the None singleton.

props.secondary_icon_tooltip_text: str#

The type of the None singleton.

props.show_emoji_icon: bool#

The type of the None singleton.

props.tabs: TabArray#

The type of the None singleton.

props.text_length: int#

The type of the None singleton.

props.truncate_multiline: bool#

The type of the None singleton.

props.visibility: bool#

The type of the None singleton.

Signals#

class Entry.signals
activate() None#

Emitted when the entry is activated.

The keybindings for this signal are all forms of the Enter key.

icon_press(icon_pos: EntryIconPosition) None#

The type of the None singleton.

Parameters:

icon_pos – The position of the clicked icon

icon_release(icon_pos: EntryIconPosition) None#

The type of the None singleton.

Parameters:

icon_pos – The position of the clicked icon

Virtual Methods#

class Entry
do_activate() None#

Class handler for the GtkEntry::activate signal. The default implementation activates the gtk.activate-default action.

Fields#

class Entry
parent_instance#