# `Plushie.Table.Row`
[🔗](https://github.com/plushie-ui/plushie-elixir/blob/v0.7.2/lib/plushie/table/row.ex#L1)

A row inside a `table` widget.

Each row has an explicit ID used for selection events and
LIS-based wire diffing. Children are `Plushie.Table.Cell`
elements, one per column.

    table_row "user-1" do
      cell "name", text(user.name)
      cell "email", text(user.email)
    end

# `option`

```elixir
@type option() :: []
```

# `t`

```elixir
@type t() :: %Plushie.Table.Row{
  children: [Plushie.Widget.ui_node()],
  id: String.t() | nil
}
```

# `build`

```elixir
@spec build(widget :: t()) :: Plushie.Widget.ui_node()
```

Converts this widget struct to a `ui_node()` map.

# `extend`

```elixir
@spec extend(widget :: t(), children :: [Plushie.Widget.child()]) :: t()
```

Appends multiple children to the widget.

# `new`

```elixir
@spec new(opts :: [option()]) :: t()
```

Creates a new element without an explicit ID (auto-assigned by parent container).

# `new`

```elixir
@spec new(id :: String.t(), opts :: [option()]) :: t()
```

Creates a new element with the given ID and keyword options.

# `push`

```elixir
@spec push(widget :: t(), child :: Plushie.Widget.child()) :: t()
```

Appends a child to the widget.

# `type_name`

```elixir
@spec type_name() :: String.t()
```

Returns the element type string for the wire protocol.

# `with_options`

```elixir
@spec with_options(widget :: t(), opts :: [option()]) :: t()
```

Applies keyword options to an existing widget struct.

---

*Consult [api-reference.md](api-reference.md) for complete listing*
