Applications
Tabs

Tabs

Underline Example

Sample Code

Underline Tabs
import { useState } from "react";
import { MagicTabSelect } from "react-magic-motion";
 
const underlineTabs = ["Recipes 🧑‍🍳", "Notes 📝", "Programming 🧑‍💻"];
 
export default function UnderlineTabs() {
  const [selectedIndex, setSelectedIndex] = useState(1);
 
  const tabsComponents = underlineTabs.map((text, i) => {
    return (
      <button
        type="button"
        key={`tab-${text}`}
        onClick={() => setSelectedIndex(i)}
        style={{
          padding: "0.65rem 0.75rem",
          backgroundColor: "rgba(238, 238, 238)",
          border: 0,
          cursor: "pointer",
        }}
      >
        {text}
 
        {selectedIndex === i && (
          <div style={{ position: "relative", transform: "translateY(3px)" }}>
            <MagicTabSelect
              id="underline"
              transition={{ type: "spring", bounce: 0.3 }}
            >
              <div
                style={{
                  width: "100%",
                  height: "0.15rem",
                  backgroundColor: "black",
                  position: "absolute",
                }}
              />
            </MagicTabSelect>
          </div>
        )}
      </button>
    );
  });
 
  return <div style={{ display: "flex", gap: "0.5rem" }}>{tabsComponents}</div>;
}

Pill Example

Sample Code

Pill Tabs
import { useState } from "react";
import { MagicTabSelect } from "react-magic-motion";
 
const pillTabs = ["Hobbies", "Work", "Projects", "Languages"];
 
export function PillTabs() {
  const [selectedIndex, setSelectedIndex] = useState(1);
 
  const tabsComponents = pillTabs.map((text, i) => {
    return (
      <button
        key={text}
        onClick={() => setSelectedIndex(i)}
        style={{
          position: "relative",
          padding: "0.65rem 0.75rem",
          backgroundColor: "black",
          color: "white",
        }}
      >
        {selectedIndex === i && (
          <MagicTabSelect
            id="pillTabs"
            transition={{ type: "spring", bounce: 0.35 }}
          >
            <span
              style={{
                borderRadius: "999px",
                position: "absolute",
                top: 0,
                left: 0,
                right: 0,
                bottom: 0,
                zIndex: 10,
                backgroundColor: "white",
                mixBlendMode: "difference",
              }}
            />
          </MagicTabSelect>
        )}
        {text}
      </button>
    );
  });
 
  return (
    <div style={{ display: "flex", gap: "0.75rem", margin: "0.75rem 0" }}>
      {tabsComponents}
    </div>
  );
}