

-- This will add a label called "greeting" to the top flow.
-- Immediately after, it will change its text to illustrate accessing child elements.
game.player.gui.top.add{type="label", name="greeting", caption="Hi"}
game.player.gui.top.greeting.caption = "Hello there!"
game.player.gui.top["greeting"].caption = "Actually, never mind, I don't like your face"
-- This will add a tabbed-pane and 2 tabs with contents.
local tabbed_pane = game.player.gui.top.add{type="tabbed-pane"}
local tab1 = tabbed_pane.add{type="tab", caption="Tab 1"}
local tab2 = tabbed_pane.add{type="tab", caption="Tab 2"}
local label1 = tabbed_pane.add{type="label", caption="Label 1"}
local label2 = tabbed_pane.add{type="label", caption="Label 2"}
tabbed_pane.add_tab(tab1, label1)
tabbed_pane.add_tab(tab2, label2)
| add{type=…, name?=…, caption?=…, tooltip?=…, elem_tooltip?=…, enabled?=…, visible?=…, locked?=…, ignored_by_interaction?=…, style?=…, tags?=…, index?=…, anchor?=…, game_controller_interaction?=…, raise_hover_events?=…} | → LuaGuiElement | Add a new child element to this GuiElement. | 
| Add a new child element to this GuiElement. | ||
| clear() | Remove children of this element. [...] | |
| Remove children of this element. [...] | ||
| destroy() | Remove this element, along with its children. [...] | |
| Remove this element, along with its children. [...] | ||
| get_mod() | → string? | The mod that owns this Gui element or  | 
| The mod that owns this Gui element or  | ||
| get_index_in_parent() | → uint32 | Gets the index that this element has in its parent element. [...] | 
| Gets the index that this element has in its parent element. [...] | ||
| swap_children(index_1, index_2) | Swaps the children at the given indices in this element. | |
| Swaps the children at the given indices in this element. | ||
| clear_items() | Removes the items in this dropdown or listbox. | |
| Removes the items in this dropdown or listbox. | ||
| get_item(index) | → LocalisedString | Gets the item at the given index from this dropdown or listbox. | 
| Gets the item at the given index from this dropdown or listbox. | ||
| set_item(index, string) | Sets the given string at the given index in this dropdown or listbox. | |
| Sets the given string at the given index in this dropdown or listbox. | ||
| add_item(string, index?) | Inserts a string at the end or at the given index of this dropdown or listbox. | |
| Inserts a string at the end or at the given index of this dropdown or listbox. | ||
| remove_item(index) | Removes the item at the given index from this dropdown or listbox. | |
| Removes the item at the given index from this dropdown or listbox. | ||
| get_slider_minimum() | → double | Gets this sliders minimum value. | 
| Gets this sliders minimum value. | ||
| get_slider_maximum() | → double | Gets this sliders maximum value. | 
| Gets this sliders maximum value. | ||
| set_slider_minimum_maximum(minimum, maximum) | Sets this sliders minimum and maximum values. [...] | |
| Sets this sliders minimum and maximum values. [...] | ||
| get_slider_value_step() | → double | Gets the minimum distance this slider can move. | 
| Gets the minimum distance this slider can move. | ||
| get_slider_discrete_values() | → boolean | Returns whether this slider only allows discrete values. | 
| Returns whether this slider only allows discrete values. | ||
| set_slider_value_step(value) | Sets the minimum distance this slider can move. [...] | |
| Sets the minimum distance this slider can move. [...] | ||
| set_slider_discrete_values(value) | Sets whether this slider only allows discrete values. | |
| Sets whether this slider only allows discrete values. | ||
| focus() | Focuses this GUI element if possible. | |
| Focuses this GUI element if possible. | ||
| scroll_to_top() | Scrolls this scroll bar to the top. | |
| Scrolls this scroll bar to the top. | ||
| scroll_to_bottom() | Scrolls this scroll bar to the bottom. | |
| Scrolls this scroll bar to the bottom. | ||
| scroll_to_left() | Scrolls this scroll bar to the left. | |
| Scrolls this scroll bar to the left. | ||
| scroll_to_right() | Scrolls this scroll bar to the right. | |
| Scrolls this scroll bar to the right. | ||
| scroll_to_element(element, scroll_mode?) | Scrolls this scroll bar such that the specified GUI element is visible to the player. | |
| Scrolls this scroll bar such that the specified GUI element is visible to the player. | ||
| select_all() | Selects all the text in this textbox. | |
| Selects all the text in this textbox. | ||
| select(start_index, end_index) | Selects a range of text in this textbox. | |
| Selects a range of text in this textbox. | ||
| add_tab(tab, content) | Adds the given tab and content widgets to this tabbed pane as a new tab. | |
| Adds the given tab and content widgets to this tabbed pane as a new tab. | ||
| remove_tab(tab?) | Removes the given tab and its associated content from this tabbed pane. [...] | |
| Removes the given tab and its associated content from this tabbed pane. [...] | ||
| force_auto_center() | Forces this frame to re-auto-center. [...] | |
| Forces this frame to re-auto-center. [...] | ||
| scroll_to_item(index, scroll_mode?) | Scrolls the scroll bar such that the specified listbox item is visible to the player. | |
| Scrolls the scroll bar such that the specified listbox item is visible to the player. | ||
| bring_to_front() | Moves this GUI element to the "front" so it will draw over other elements. [...] | |
| Moves this GUI element to the "front" so it will draw over other elements. [...] | ||
| close_dropdown() | Closes the dropdown list if this is a dropdown and it is open. | |
| Closes the dropdown list if this is a dropdown and it is open. | ||
| index | :: R uint32 | The index of this GUI element (unique amongst the GUI elements of a LuaPlayer). | 
| The index of this GUI element (unique amongst the GUI elements of a LuaPlayer). | ||
| gui | :: R LuaGui | The GUI this element is a child of. | 
| The GUI this element is a child of. | ||
| parent | :: R LuaGuiElement? | The direct parent of this element. [...] | 
| The direct parent of this element. [...] | ||
| name | :: RW string | The name of this element. [...] | 
| The name of this element. [...] | ||
| caption | :: RW LocalisedString | The text displayed on this element. [...] | 
| The text displayed on this element. [...] | ||
| value | :: RW double | How much this progress bar is filled. [...] | 
| How much this progress bar is filled. [...] | ||
| direction | :: R GuiDirection | Direction of this element's layout. | 
| Direction of this element's layout. | ||
| style | :: RW LuaStyle or string | The style of this element. [...] | 
| The style of this element. [...] | ||
| visible | :: RW boolean | Sets whether this GUI element is visible or completely hidden, taking no space in the layout. | 
| Sets whether this GUI element is visible or completely hidden, taking no space in the layout. | ||
| text | :: RW string | The text contained in this textfield or text-box. | 
| The text contained in this textfield or text-box. | ||
| children_names | :: R array[string] | Names of all the children of this element. [...] | 
| Names of all the children of this element. [...] | ||
| state | :: RW boolean | Is this checkbox or radiobutton checked? | 
| Is this checkbox or radiobutton checked? | ||
| player_index | :: R uint32 | Index into LuaGameScript::players specifying the player who owns this element. | 
| Index into LuaGameScript::players specifying the player who owns this element. | ||
| sprite | :: RW SpritePath | The sprite to display on this sprite-button or sprite in the default state. | 
| The sprite to display on this sprite-button or sprite in the default state. | ||
| resize_to_sprite | :: RW boolean | Whether the sprite widget should resize according to the sprite in it. [...] | 
| Whether the sprite widget should resize according to the sprite in it. [...] | ||
| hovered_sprite | :: RW SpritePath | The sprite to display on this sprite-button when it is hovered. | 
| The sprite to display on this sprite-button when it is hovered. | ||
| clicked_sprite | :: RW SpritePath | The sprite to display on this sprite-button when it is clicked. | 
| The sprite to display on this sprite-button when it is clicked. | ||
| tooltip | :: RW LocalisedString | The text to display when hovering over this element. [...] | 
| The text to display when hovering over this element. [...] | ||
| elem_tooltip | :: RW ElemID? | The element tooltip to display when hovering over this element, or  | 
| The element tooltip to display when hovering over this element, or  | ||
| horizontal_scroll_policy | :: RW ScrollPolicy | Policy of the horizontal scroll bar. | 
| Policy of the horizontal scroll bar. | ||
| vertical_scroll_policy | :: RW ScrollPolicy | Policy of the vertical scroll bar. | 
| Policy of the vertical scroll bar. | ||
| type | :: R GuiElementType | The type of this GUI element. | 
| The type of this GUI element. | ||
| children | :: R array[LuaGuiElement] | The child-elements of this GUI element. | 
| The child-elements of this GUI element. | ||
| items | :: RW array[LocalisedString] | The items in this dropdown or listbox. | 
| The items in this dropdown or listbox. | ||
| selected_index | :: RW uint32 | The selected index for this dropdown or listbox. [...] | 
| The selected index for this dropdown or listbox. [...] | ||
| quality | :: R LuaQualityPrototype | W QualityID? | The quality to be shown in the bottom left corner of this sprite-button, or  | 
| The quality to be shown in the bottom left corner of this sprite-button, or  | ||
| number | :: RW double? | The number to be shown in the bottom right corner of this sprite-button, or  | 
| The number to be shown in the bottom right corner of this sprite-button, or  | ||
| show_percent_for_small_numbers | :: RW boolean | Related to the number to be shown in the bottom right corner of this sprite-button. [...] | 
| Related to the number to be shown in the bottom right corner of this sprite-button. [...] | ||
| location | :: RW GuiLocation? | The location of this widget when stored in LuaGui::screen. [...] | 
| The location of this widget when stored in LuaGui::screen. [...] | ||
| auto_center | :: RW boolean | Whether this frame auto-centers on window resize when stored in LuaGui::screen. | 
| Whether this frame auto-centers on window resize when stored in LuaGui::screen. | ||
| badge_text | :: RW LocalisedString | The text to display after the normal tab text (designed to work with numbers) | 
| The text to display after the normal tab text (designed to work with numbers) | ||
| auto_toggle | :: RW boolean | Whether this button will automatically toggle when clicked. | 
| Whether this button will automatically toggle when clicked. | ||
| toggled | :: RW boolean | Whether this button is currently toggled. [...] | 
| Whether this button is currently toggled. [...] | ||
| game_controller_interaction | :: RW defines.game_controller_interaction | How this element should interact with game controllers. | 
| How this element should interact with game controllers. | ||
| position | :: RW MapPosition | The position this camera or minimap is focused on, if any. | 
| The position this camera or minimap is focused on, if any. | ||
| surface_index | :: RW uint32 | The surface index this camera or minimap is using. | 
| The surface index this camera or minimap is using. | ||
| zoom | :: RW double | The zoom this camera or minimap is using. [...] | 
| The zoom this camera or minimap is using. [...] | ||
| minimap_player_index | :: RW uint32 | The player index this minimap is using. | 
| The player index this minimap is using. | ||
| force | :: RW string? | The force this minimap is using, if any. | 
| The force this minimap is using, if any. | ||
| elem_type | :: R ElemType | The elem type of this choose-elem-button. | 
| The elem type of this choose-elem-button. | ||
| elem_value | :: RW string or SignalID or PrototypeWithQuality? | The elem value of this choose-elem-button, if any. [...] | 
| The elem value of this choose-elem-button, if any. [...] | ||
| elem_filters | :: RW PrototypeFilter? | The elem filters of this choose-elem-button, if any. [...] | 
| The elem filters of this choose-elem-button, if any. [...] | ||
| selectable | :: RW boolean | Whether the contents of this text-box are selectable. [...] | 
| Whether the contents of this text-box are selectable. [...] | ||
| word_wrap | :: RW boolean | Whether this text-box will word-wrap automatically. [...] | 
| Whether this text-box will word-wrap automatically. [...] | ||
| read_only | :: RW boolean | Whether this text-box is read-only. [...] | 
| Whether this text-box is read-only. [...] | ||
| enabled | :: RW boolean | Whether this GUI element is enabled. [...] | 
| Whether this GUI element is enabled. [...] | ||
| ignored_by_interaction | :: RW boolean | Whether this GUI element is ignored by interaction. [...] | 
| Whether this GUI element is ignored by interaction. [...] | ||
| locked | :: RW boolean | Whether this choose-elem-button can be changed by the player. | 
| Whether this choose-elem-button can be changed by the player. | ||
| draw_vertical_lines | :: RW boolean | Whether this table should draw vertical grid lines. | 
| Whether this table should draw vertical grid lines. | ||
| draw_horizontal_lines | :: RW boolean | Whether this table should draw horizontal grid lines. | 
| Whether this table should draw horizontal grid lines. | ||
| draw_horizontal_line_after_headers | :: RW boolean | Whether this table should draw a horizontal grid line below the first table row. | 
| Whether this table should draw a horizontal grid line below the first table row. | ||
| column_count | :: R uint32 | The number of columns in this table. | 
| The number of columns in this table. | ||
| vertical_centering | :: RW boolean | Whether the content of this table should be vertically centered. [...] | 
| Whether the content of this table should be vertically centered. [...] | ||
| slider_value | :: RW double | The value of this slider element. | 
| The value of this slider element. | ||
| mouse_button_filter | :: RW MouseButtonFlags | The mouse button filters for this button or sprite-button. | 
| The mouse button filters for this button or sprite-button. | ||
| numeric | :: RW boolean | Whether this textfield is limited to only numeric characters. | 
| Whether this textfield is limited to only numeric characters. | ||
| allow_decimal | :: RW boolean | Whether this textfield (when in numeric mode) allows decimal numbers. | 
| Whether this textfield (when in numeric mode) allows decimal numbers. | ||
| allow_negative | :: RW boolean | Whether this textfield (when in numeric mode) allows negative numbers. | 
| Whether this textfield (when in numeric mode) allows negative numbers. | ||
| is_password | :: RW boolean | Whether this textfield displays as a password field, which renders all characters as  | 
| Whether this textfield displays as a password field, which renders all characters as  | ||
| lose_focus_on_confirm | :: RW boolean | Whether this textfield loses focus after defines.events.on_gui_confirmed is fired. | 
| Whether this textfield loses focus after defines.events.on_gui_confirmed is fired. | ||
| icon_selector | :: R boolean | Whether this textfield or text-box was created with an icon selector. | 
| Whether this textfield or text-box was created with an icon selector. | ||
| drag_target | :: RW LuaGuiElement? | The  | 
| The  | ||
| selected_tab_index | :: RW uint32? | The selected tab index for this tabbed pane, if any. | 
| The selected tab index for this tabbed pane, if any. | ||
| tabs | :: R array[TabAndContent] | The tabs and contents being shown in this tabbed-pane. | 
| The tabs and contents being shown in this tabbed-pane. | ||
| entity | :: RW LuaEntity? | The entity associated with this entity-preview, camera, minimap, if any. | 
| The entity associated with this entity-preview, camera, minimap, if any. | ||
| anchor | :: RW GuiAnchor? | The anchor for this relative widget, if any. [...] | 
| The anchor for this relative widget, if any. [...] | ||
| tags | :: RW Tags | The tags associated with this LuaGuiElement. | 
| The tags associated with this LuaGuiElement. | ||
| raise_hover_events | :: RW boolean | Whether this element will raise on_gui_hover and on_gui_leave. | 
| Whether this element will raise on_gui_hover and on_gui_leave. | ||
| switch_state | :: RW SwitchState | The switch state for this switch. [...] | 
| The switch state for this switch. [...] | ||
| allow_none_state | :: RW boolean | Whether the  | 
| Whether the  | ||
| left_label_caption | :: RW LocalisedString | The text shown for the left switch label. | 
| The text shown for the left switch label. | ||
| left_label_tooltip | :: RW LocalisedString | The tooltip shown on the left switch label. | 
| The tooltip shown on the left switch label. | ||
| right_label_caption | :: RW LocalisedString | The text shown for the right switch label. | 
| The text shown for the right switch label. | ||
| right_label_tooltip | :: RW LocalisedString | The tooltip shown on the right switch label. | 
| The tooltip shown on the right switch label. | ||
| valid | :: R boolean | Is this object valid? [...] | 
| Is this object valid? [...] | ||
| object_name | :: R string | The class name of this object. [...] | 
| The class name of this object. [...] | ||
| [] (index) | :: R LuaGuiElement? | The indexing operator. [...] | 
| The indexing operator. [...] | ||

| type | :: GuiElementType | The kind of element to add, which potentially has its own attributes as listed below. | 
| The kind of element to add, which potentially has its own attributes as listed below. | ||
| name | :: string? | Name of the child element. It must be unique within the parent element. | 
| Name of the child element. It must be unique within the parent element. | ||
| caption | :: LocalisedString? | Text displayed on the child element. For frames, this is their title. For other elements, like buttons or labels, this is the content. Whilst this attribute may be used on all elements, it doesn't make sense for tables and flows as they won't display it. | 
| Text displayed on the child element. For frames, this is their title. For other elements, like buttons or labels, this is the content. Whilst this attribute may be used on all elements, it doesn't make sense for tables and flows as they won't display it. | ||
| tooltip | :: LocalisedString? | Tooltip of the child element. | 
| Tooltip of the child element. | ||
| elem_tooltip | :: ElemID? | Elem tooltip of the child element. Will be displayed above  | 
| Elem tooltip of the child element. Will be displayed above  | ||
| enabled | :: boolean? | Whether the child element is enabled. Defaults to  | 
| Whether the child element is enabled. Defaults to  | ||
| visible | :: boolean? | Whether the child element is visible. Defaults to  | 
| Whether the child element is visible. Defaults to  | ||
| locked | :: boolean? | Whether the child element is locked. Defaults to  | 
| Whether the child element is locked. Defaults to  | ||
| ignored_by_interaction | :: boolean? | Whether the child element is ignored by interaction. Defaults to  | 
| Whether the child element is ignored by interaction. Defaults to  | ||
| style | :: string? | The name of the style prototype to apply to the new element. | 
| The name of the style prototype to apply to the new element. | ||
| tags | :: Tags? | Tags associated with the child element. | 
| Tags associated with the child element. | ||
| index | :: uint32? | Location in its parent that the child element should slot into. By default, the child will be appended onto the end. | 
| Location in its parent that the child element should slot into. By default, the child will be appended onto the end. | ||
| anchor | :: GuiAnchor? | Where to position the child element when in the  | 
| Where to position the child element when in the  | ||
| game_controller_interaction | :: defines.game_controller_interaction? | How the element should interact with game controllers. Defaults to defines.game_controller_interaction.normal. | 
| How the element should interact with game controllers. Defaults to defines.game_controller_interaction.normal. | ||
| raise_hover_events | :: boolean? | Whether this element will raise on_gui_hover and on_gui_leave. Defaults to  | 
| Whether this element will raise on_gui_hover and on_gui_leave. Defaults to  | ||
Other attributes may be specified depending on type:
button| mouse_button_filter | :: MouseButtonFlags? | Which mouse buttons the button responds to. Defaults to  | 
| Which mouse buttons the button responds to. Defaults to  | ||
| auto_toggle | :: boolean? | Whether the button will automatically toggle when clicked. Defaults to  | 
| Whether the button will automatically toggle when clicked. Defaults to  | ||
| toggled | :: boolean? | The initial toggled state of the button. Defaults to  | 
| The initial toggled state of the button. Defaults to  | ||
flow| direction | :: GuiDirection? | The initial direction of the flow's layout. Defaults to  | 
| The initial direction of the flow's layout. Defaults to  | ||
frame| direction | :: GuiDirection? | The initial direction of the frame's layout. Defaults to  | 
| The initial direction of the frame's layout. Defaults to  | ||
table| column_count | :: uint32 | Number of columns. This can't be changed after the table is created. | 
| Number of columns. This can't be changed after the table is created. | ||
| draw_vertical_lines | :: boolean? | Whether the table should draw vertical grid lines. Defaults to  | 
| Whether the table should draw vertical grid lines. Defaults to  | ||
| draw_horizontal_lines | :: boolean? | Whether the table should draw horizontal grid lines. Defaults to  | 
| Whether the table should draw horizontal grid lines. Defaults to  | ||
| draw_horizontal_line_after_headers | :: boolean? | Whether the table should draw a single horizontal grid line after the headers. Defaults to  | 
| Whether the table should draw a single horizontal grid line after the headers. Defaults to  | ||
| vertical_centering | :: boolean? | Whether the content of the table should be vertically centered. Defaults to  | 
| Whether the content of the table should be vertically centered. Defaults to  | ||
textfield| text | :: string? | The initial text contained in the textfield. | 
| The initial text contained in the textfield. | ||
| numeric | :: boolean? | Defaults to  | 
| Defaults to  | ||
| allow_decimal | :: boolean? | Defaults to  | 
| Defaults to  | ||
| allow_negative | :: boolean? | Defaults to  | 
| Defaults to  | ||
| is_password | :: boolean? | Defaults to  | 
| Defaults to  | ||
| lose_focus_on_confirm | :: boolean? | Defaults to  | 
| Defaults to  | ||
| icon_selector | :: boolean? | Whether to add the rich text icon selector to the text field. This attribute can't be changed after creating the widget. Defaults to  | 
| Whether to add the rich text icon selector to the text field. This attribute can't be changed after creating the widget. Defaults to  | ||
progressbar| value | :: double? | The initial value of the progressbar, in the range  | 
| The initial value of the progressbar, in the range  | ||
checkbox| state | :: boolean | The initial checked-state of the checkbox. | 
| The initial checked-state of the checkbox. | ||
radiobutton| state | :: boolean | The initial checked-state of the radiobutton. | 
| The initial checked-state of the radiobutton. | ||
sprite-button| sprite | :: SpritePath? | Path to the image to display on the button. | 
| Path to the image to display on the button. | ||
| hovered_sprite | :: SpritePath? | Path to the image to display on the button when it is hovered. | 
| Path to the image to display on the button when it is hovered. | ||
| clicked_sprite | :: SpritePath? | Path to the image to display on the button when it is clicked. | 
| Path to the image to display on the button when it is clicked. | ||
| quality | :: string? | The name of the quality shown on the button. | 
| The name of the quality shown on the button. | ||
| number | :: double? | The number shown on the button. | 
| The number shown on the button. | ||
| show_percent_for_small_numbers | :: boolean? | Formats small numbers as percentages. Defaults to  | 
| Formats small numbers as percentages. Defaults to  | ||
| mouse_button_filter | :: MouseButtonFlags? | The mouse buttons that the button responds to. Defaults to  | 
| The mouse buttons that the button responds to. Defaults to  | ||
| auto_toggle | :: boolean? | Whether the button will automatically toggle when clicked. Defaults to  | 
| Whether the button will automatically toggle when clicked. Defaults to  | ||
| toggled | :: boolean? | The initial toggled state of the button. Defaults to  | 
| The initial toggled state of the button. Defaults to  | ||
sprite| sprite | :: SpritePath? | Path to the image to display. | 
| Path to the image to display. | ||
| resize_to_sprite | :: boolean? | Whether the widget should resize according to the sprite in it. Defaults to  | 
| Whether the widget should resize according to the sprite in it. Defaults to  | ||
scroll-pane| horizontal_scroll_policy | :: ScrollPolicy? | Policy of the horizontal scroll bar. Defaults to  | 
| Policy of the horizontal scroll bar. Defaults to  | ||
| vertical_scroll_policy | :: ScrollPolicy? | Policy of the vertical scroll bar. Defaults to  | 
| Policy of the vertical scroll bar. Defaults to  | ||
drop-down| items | :: array[LocalisedString]? | The initial items in the dropdown. | 
| The initial items in the dropdown. | ||
| selected_index | :: uint32? | The index of the initially selected item. Defaults to 0. | 
| The index of the initially selected item. Defaults to 0. | ||
line| direction | :: GuiDirection? | The initial direction of the line. Defaults to  | 
| The initial direction of the line. Defaults to  | ||
list-box| items | :: array[LocalisedString]? | The initial items in the listbox. | 
| The initial items in the listbox. | ||
| selected_index | :: uint32? | The index of the initially selected item. Defaults to 0. | 
| The index of the initially selected item. Defaults to 0. | ||
camera| position | :: MapPosition | The position the camera centers on. | 
| The position the camera centers on. | ||
| surface_index | :: uint32? | The surface that the camera will render. Defaults to the player's current surface. | 
| The surface that the camera will render. Defaults to the player's current surface. | ||
| zoom | :: double? | The initial camera zoom. Defaults to  | 
| The initial camera zoom. Defaults to  | ||
choose-elem-button| elem_type | :: ElemType | The type of the button. | 
| The type of the button. | ||
| item | :: string? | If type is  | 
| If type is  | ||
| tile | :: string? | If type is  | 
| If type is  | ||
| entity | :: string? | If type is  | 
| If type is  | ||
| signal | :: SignalID? | If type is  | 
| If type is  | ||
| fluid | :: string? | If type is  | 
| If type is  | ||
| recipe | :: string? | If type is  | 
| If type is  | ||
| decorative | :: string? | If type is  | 
| If type is  | ||
| item-group | :: string? | If type is  | 
| If type is  | ||
| achievement | :: string? | If type is  | 
| If type is  | ||
| equipment | :: string? | If type is  | 
| If type is  | ||
| technology | :: string? | If type is  | 
| If type is  | ||
| asteroid-chunk | :: string? | If type is  | 
| If type is  | ||
| space-location | :: string? | If type is  | 
| If type is  | ||
| item-with-quality | :: PrototypeWithQuality? | If type is  | 
| If type is  | ||
| entity-with-quality | :: PrototypeWithQuality? | If type is  | 
| If type is  | ||
| recipe-with-quality | :: PrototypeWithQuality? | If type is  | 
| If type is  | ||
| equipment-with-quality | :: PrototypeWithQuality? | If type is  | 
| If type is  | ||
| elem_filters | :: PrototypeFilter? | Filters describing what to show in the selection window. The applicable filter depends on the  | 
| Filters describing what to show in the selection window. The applicable filter depends on the  | ||
text-box| text | :: string? | The initial text contained in the text-box. | 
| The initial text contained in the text-box. | ||
| icon_selector | :: boolean? | Whether to add the rich text icon selector to the text box. This attribute can't be changed after creating the widget. Defaults to  | 
| Whether to add the rich text icon selector to the text box. This attribute can't be changed after creating the widget. Defaults to  | ||
slider| minimum_value | :: double? | The minimum value for the slider. Defaults to  | 
| The minimum value for the slider. Defaults to  | ||
| maximum_value | :: double? | The maximum value for the slider. Defaults to  | 
| The maximum value for the slider. Defaults to  | ||
| value | :: double? | The initial value for the slider. Defaults to  | 
| The initial value for the slider. Defaults to  | ||
| value_step | :: double? | The minimum value the slider can move. Defaults to  | 
| The minimum value the slider can move. Defaults to  | ||
| discrete_values | :: boolean? | Defaults to  | 
| Defaults to  | ||
minimap| position | :: MapPosition? | The position the minimap centers on. Defaults to the player's current position. | 
| The position the minimap centers on. Defaults to the player's current position. | ||
| surface_index | :: uint32? | The surface the camera will render. Defaults to the player's current surface. | 
| The surface the camera will render. Defaults to the player's current surface. | ||
| chart_player_index | :: uint32? | The player index the map should use. Defaults to the current player. | 
| The player index the map should use. Defaults to the current player. | ||
| force | :: string? | The force this minimap should use. Defaults to the player's current force. | 
| The force this minimap should use. Defaults to the player's current force. | ||
| zoom | :: double? | The initial camera zoom. Defaults to  | 
| The initial camera zoom. Defaults to  | ||
tab| badge_text | :: LocalisedString? | The text to display after the normal tab text (designed to work with numbers). | 
| The text to display after the normal tab text (designed to work with numbers). | ||
switch| switch_state | :: SwitchState? | If set to "none",  | 
| If set to "none",  | ||
| allow_none_state | :: boolean? | Whether the switch can be set to a middle state. Defaults to  | 
| Whether the switch can be set to a middle state. Defaults to  | ||
| left_label_caption | :: LocalisedString? | |
| left_label_tooltip | :: LocalisedString? | |
| right_label_caption | :: LocalisedString? | |
| right_label_tooltip | :: LocalisedString? | |
| → LuaGuiElement | The GUI element that was added. | 



| index | :: uint32 | The index to get | 
| The index to get | ||

| index | :: uint32 | The index whose text to replace. | 
| The index whose text to replace. | ||
| string | :: LocalisedString | The text to set at the given index. | 
| The text to set at the given index. | ||

| string | :: LocalisedString | The text to insert. | 
| The text to insert. | ||
| index | :: uint32? | The index at which to insert the item. | 
| The index at which to insert the item. | ||





| element | :: LuaGuiElement | The element to scroll to. | 
| The element to scroll to. | ||
| scroll_mode | :: "in-view"or"top-third"? | Where the element should be positioned in the scroll-pane. Defaults to  | 
| Where the element should be positioned in the scroll-pane. Defaults to  | ||

| start_index | :: int32 | The index of the first character to select | 
| The index of the first character to select | ||
| end_index | :: int32 | The index of the last character to select | 
| The index of the last character to select | ||
-- Select the characters "amp" from "example":
textbox.select(3, 5)
-- Move the cursor to the start of the text box:
textbox.select(1, 0)

| tab | :: LuaGuiElement | The tab to add, must be a GUI element of type "tab". | 
| The tab to add, must be a GUI element of type "tab". | ||
| content | :: LuaGuiElement | The content to show when this tab is selected. Can be any type of GUI element. | 
| The content to show when this tab is selected. Can be any type of GUI element. | ||

| tab | :: LuaGuiElement? | The tab to remove or  | 
| The tab to remove or  | ||

| index | :: int32 | The item index to scroll to. | 
| The item index to scroll to. | ||
| scroll_mode | :: "in-view"or"top-third"? | Where the item should be positioned in the list-box. Defaults to  | 
| Where the item should be positioned in the list-box. Defaults to  | ||




game.player.gui.top.greeting.name == "greeting"





































-- This will configure a choose-elem-button of type "entity" to only show items of type "furnace".
button.elem_filters = {{filter = "type", type = "furnace"}}
-- Then, there are some types of filters that work on a specific kind of attribute. The following will configure a
--   choose-elem-button of type "entity" to only show entities that have their `hidden` property set to `true`.
button.elem_filters = {{filter = "hidden"}}
-- Lastly, these filters can be combined at will, taking care to specify how they should be combined (either "and" or "or").
--   The following will filter for any entities that are "furnaces" and that are not "hidden".
button.elem_filters = {{filter = "type", type = "furnace"}, {filter = "hidden", invert = true, mode = "and"}}




















-- This creates a frame that contains a dragging handle which can move the frame.
local frame = player.gui.screen.add{type="frame", direction="vertical"}
local dragger = frame.add{type="empty-widget", style="draggable_space"}
dragger.style.size = {128, 24}
dragger.drag_target = frame













