---
title: "BeyondBoundsLayout"
description: "Layout extra items in the specified direction.

A [BeyondBoundsLayout] instance can be obtained by searching the tree using
[DelegatableNode.findNearestBeyondBoundsLayoutAncestor()]. It can be used to send a request to
layout more items in a particular [direction][LayoutDirection]. This can be useful when
composition or layout is determined lazily, as with a LazyColumn. The request is received by any
parent up the hierarchy that provides this modifier local."
type: "interface"
---

<div class='type'>Interface</div>


<a id='references'></a>

<div class='sourceset sourceset-common'>Common</div>



```kotlin
interface BeyondBoundsLayout
```


Layout extra items in the specified direction.

A `BeyondBoundsLayout` instance can be obtained by searching the tree using
`DelegatableNode.findNearestBeyondBoundsLayoutAncestor()`. It can be used to send a request to
layout more items in a particular `direction`. This can be useful when
composition or layout is determined lazily, as with a LazyColumn. The request is received by any
parent up the hierarchy that provides this modifier local.


## Functions

```kotlin
fun <T> layout(direction: LayoutDirection, block: BeyondBoundsScope.() -> T?): T?
```


Send a request to layout more items in the specified `direction`. The
request is received by a parent up the hierarchy. The parent adds one item at a time and
calls `block` after each item is added. The parent continues adding new items as long as
`block` returns null. Once you have all the items you need, you can perform some operation
and return a non-null value. Returning this value stops the laying out of beyond bounds
items. (Note that you have to return a non-null value stop iterating).

#### Parameters

| | |
| --- | --- |
| direction | The direction from the visible bounds in which more items are requested. |
| block | Continue to layout more items until this block returns a non null item. |


#### Returns

| | |
| --- | --- |
|  | The value returned by the last run of `block`. If we layout all the available items then the returned value is null. When this function returns all the beyond bounds items may be disposed. Therefore you have to perform any custom logic within the `block` and return the value you need. |




