Footer

Check out Footers Are Underrated and Footers 101 from Nielsen Norman Group. Footers are awesome. Go wild!

Note: in the examples below the spacing is a little off. This won't happen in practice though if you do something like this:

export default () => {
  return (
    <>
      <Navbar />
      <Container size="xl">
        <Component />
      </Container>
      <Footer />
    </>
  );
}

Note: check out this CSS Tricks article on how to get a footer that alawys stays at the bottom of the page (something you'll probably want). My preferred approach is to utilize flexbox by wrapping the Navar, Container and Footer in a Stack like so:

export default () => {
  return (
    <Stack className="min-h-screen">
      <Navbar />
      <Container size="xl" className="grow">
        <Component />
      </Container>
      <Footer />
    </Stack>
  );
}
Source code
import { 
  Footer,
  FooterColumn,
  FooterHeading,
  FooterItem
} from "rfui-package";

#Basic

<Footer>
  <FooterColumn>
    <FooterHeading>About</FooterHeading>
    <FooterItem href="/about">About</FooterItem>
    <FooterItem href="/philosophy">Philosophy</FooterItem>
    <FooterItem href="https://github.com/users/adamzerner/projects/2">
      Roadmap
    </FooterItem>
  </FooterColumn>
  <FooterColumn>
    <FooterHeading>Docs</FooterHeading>
    <FooterItem href="/">Components</FooterItem>
    <FooterItem href="/getting-started">Getting started</FooterItem>
    <FooterItem href="/tutorial">Tutorial</FooterItem>
  </FooterColumn>
</Footer>

#Empty background

Set background to "none".
Note: A dark color is often preferred as a way to distinguish the main content from the footer content.
<Footer background="none">
  <FooterColumn>
    <FooterHeading background="none">About</FooterHeading>
    <FooterItem href="/about">About</FooterItem>
    <FooterItem href="/philosophy">Philosophy</FooterItem>
    <FooterItem href="https://github.com/users/adamzerner/projects/2">
      Roadmap
    </FooterItem>
  </FooterColumn>
  <FooterColumn>
    <FooterHeading background="none">Docs</FooterHeading>
    <FooterItem href="/">Components</FooterItem>
    <FooterItem href="/getting-started">Getting started</FooterItem>
    <FooterItem href="/tutorial">Tutorial</FooterItem>
  </FooterColumn>
</Footer>

#Without default margin

By default, there is a top margin applied to the footer. This is helpful by providing a sensible default. However, you can override this default margin if you'd like as shown below.
The example below uses Tailwind's imporant modifier to make sure that the custom margin takes precedence over the original margin. You may need or want to take a different approach.
<Footer className="!mt-0">
  <FooterColumn>
    <FooterHeading>About</FooterHeading>
    <FooterItem href="/about">About</FooterItem>
    <FooterItem href="/philosophy">Philosophy</FooterItem>
    <FooterItem href="https://github.com/users/adamzerner/projects/2">
      Roadmap
    </FooterItem>
  </FooterColumn>
  <FooterColumn>
    <FooterHeading>Docs</FooterHeading>
    <FooterItem href="/">Components</FooterItem>
    <FooterItem href="/getting-started">Getting started</FooterItem>
    <FooterItem href="/tutorial">Tutorial</FooterItem>
  </FooterColumn>
</Footer>

#Props

PropRequiredDefaultType and notes
size-"md"
"sm" | "md" | "lg" | "xl"
Set this to the same value as the Container.
background-"neutral"
"neutral" | "none"
A dark color is often preferred as a way to distinguish the main content from the footer content.
children-
ComponentChild
...rest--
Omit<ComponentProps<"footer">, "size">
See the docs for rest parameters. For Footer, you could pass anything you normally would pass to <footer> because the return value looks something like this:
<footer className={containerClass} {...restWithoutClass}>
  {children}
</footer>

FooterColumn

PropRequiredDefaultType and notes
children-
ComponentChild

FooterHeading

PropRequiredDefaultType and notes
background-"neutral"
"neutral" | "none"
children-
ComponentChild

FooterItem

PropRequiredDefaultType and notes
href-
string
children-
ComponentChild