Skip to content

IndexField

petute edited this page Aug 26, 2021 · 19 revisions

IndexField

Table of Contents

Code

import {IndexField} from '@snek-at/jaen'

const Section = (): JSX.Element => (
    return(
      <>
        <IndexField 
          fixedSlug="yourSlug"
          outerElement={() => <YourHtmlTag />}
          renderItem={(item, key, navigate) => (
            return(
              <>
                <div key={key}>
                  <button onClick={navigate}>
                    {item.title}
                  </button>
                </div>
              </>
            )
          )}
          />
      </>
    )
)

Description

The IndexField provides an easy way to link to childpages of a slug or to fetch data of childpages and build cards on any page in your project. It is not possible to edit the text on these components for that job please look at our StreamField.

Parameters

fixedSlug

fixedSlug={"yourSlug"}

The fixedSlug property is not required. If it is not specified the IndexField will take the children of the current page. It allows you to decide which pages children are used.

outerElement

outerElement={() => <YourHtmlTag />}

The outerElement allows you to wrap your cards, buttons or more into a div, Flex etc. in order to position the elements correctly on your page.

renderItem

renderItem={(item, key, navigate) => (
    return(
      <>
        <div key={key}>
          <button onClick={navigate}>
            {item.title}
          </button>
        </div>
      </>
    )
)}

renderItem allows you to build React-Components of any kind.

item: object

item.slug
Slug holds the slug of the current childpage. This property can be used to fetch data from the current childpage to build cards.

item.title
Title provides you with the title of the current childpage. This can be used to fill buttons our links.

key: number

The key should be used to give fill the key parameter of the html tags.

navigate: () => void

navigate can be used to fill an onClick event on buttons or links to link to the current childpage.

Code Sandbox

WIP

Clone this wiki locally