# 7. FeedPage

![FeedPage](https://1632916805-files.gitbook.io/~/files/v0/b/gitbook-legacy-files/o/assets%2F-L_tOQ0x4-szpVU0FZV4%2F-L_v97h5BiwsRuNJ-MWN%2F-L_v99C9Y8Ls1H5qWlJP%2Fklaystagram-feedpage.png?generation=1552549499715940\&alt=media)

FeedPage is consisted of 3 main components that interact with `Klaystagram` contract.

[7-2. `UploadPhoto` component](https://klaytn.gitbook.io/docs/bapp/tutorials/klaystagram/7.-feedpage/7-2.-uploadphoto-component)\
[7-3. `Feed` component](https://klaytn.gitbook.io/docs/bapp/tutorials/klaystagram/7.-feedpage/7-3.-feed-component)\
[7-4. `TransferOwnership` component](https://klaytn.gitbook.io/docs/bapp/tutorials/klaystagram/7.-feedpage/7-4.-transferownership-component)

```javascript
// src/pages/FeedPage.js

const FeedPage = () => (
  <main className="FeedPage">
    <UploadButton />               // 7-2. UploadPhoto
    <Feed />                       // 7-3. Feed
  </main>
)
```

```javascript
// src/components/Feed.js

<div className="Feed">
  {feed.length !== 0
    ? feed.map((photo) => {
      // ...
      return (
        <div className="FeedPhoto" key={id}>

            // ...
            {
              userAddress === currentOwner && (
                <TransferOwnershipButton   // 7-4. TransferOwnership
                  className="FeedPhoto__transferOwnership"
                  id={id}
                  issueDate={issueDate}
                  currentOwner={currentOwner}
                />
              )
            }
            // ...
        </div>
      )
    })
    : <span className="Feed__empty">No Photo :D</span>
  }
</div>
)
```

To make component interact with contract, there are 3 steps.

**First**, create `KlaystagramContract` instance to connect contract with front-end. **Second**, using `KlaystagramContract` instance, make API functions that interact with contract in `redux/actions`\
**Third**, call functions in each component

Let's build it!
