> ## Documentation Index
> Fetch the complete documentation index at: https://developer.box.com/llms.txt
> Use this file to discover all available pages before exploring further.

# UI Elements in Salesforce

export const MultiRelatedLinks = ({sections = []}) => {
  if (!sections || sections.length === 0) {
    return null;
  }
  return <div className="space-y-8">
      {sections.map((section, index) => <RelatedLinks key={index} title={section.title} items={section.items} />)}
    </div>;
};

export const RelatedLinks = ({title, items = []}) => {
  const getBadgeClass = badge => {
    if (!badge) return "badge-default";
    const badgeType = badge.toLowerCase().replace(/\s+/g, "-");
    return `badge-${badge === "ガイド" ? "guide" : badgeType}`;
  };
  if (!items || items.length === 0) {
    return null;
  }
  return <div className="my-8">
      {}
      <h3 className="text-sm font-bold uppercase tracking-wider mb-4">{title}</h3>

      {}
      <div className="flex flex-col gap-3">
        {items.map((item, index) => <a key={index} href={item.href} className="py-2 px-3 rounded related_link hover:bg-[#f2f2f2] dark:hover:bg-[#111827] flex items-center gap-3 group no-underline hover:no-underline border-b-0">
            {}
            <span className={`px-2 py-1 rounded-full text-xs font-semibold uppercase tracking-wide flex-shrink-0 ${getBadgeClass(item.badge)}`}>
              {item.badge}
            </span>

            {}
            <span className="text-base">{item.label}</span>
          </a>)}
      </div>
    </div>;
};

export const Link = ({href, children, className, ...props}) => {
  const localizedHref = href;
  return <a href={localizedHref} className={className} {...props}>
      {children}
    </a>;
};

The Box for Salesforce managed package offers the following
<Link href="/guides/embed/ui-elements">UI Elements</Link> as Lightning Components: <Link href="/guides/embed/ui-elements/picker">content picker</Link>,
<Link href="/guides/embed/ui-elements/explorer">explorer</Link>, <Link href="/guides/embed/ui-elements/preview">preview</Link>, and <Link href="/guides/embed/ui-elements/uploader">uploader</Link>. You can use them on
Lightning Pages, or in Flows.

## Content picker

<Link href="/guides/embed/ui-elements/picker/#options">Options</Link> available in picker with Box for Salesforce are:

* `folderId` - if the lightning component is on a record page, it defaults to the record folder
* `chooseButtonLabel`
* `cancelButtonLabel`
* `canSetShareAccess`
* `canCreateNewFolder`
* `canUpload`
* `maxSelectable`

## Content explorer

<Link href="/guides/embed/ui-elements/explorer/#options">Options</Link> available in explorer with Box for Salesforce are:

* `folderId` - if the lightning component is on a record page, it defaults to the record folder
* `canSetShareAccess`
* `canCreateNewFolder`
* `canUpload`
* `canPreview`
* `canDownload`
* `canDelete`
* `canRename`
* `canShare`

## Content preview

<Link href="/guides/embed/ui-elements/preview/#options">Options</Link> available in preview with Box for Salesforce are:

* `fileId` (<Link href="/guides/files/get">find your file ID</Link>)
* **File Id API Field Name** - Salesforce specific; on a record page, you can use an API field name that holds the file ID to be displayed

## Content uploader

<Link href="/guides/embed/ui-elements/uploader/#options">Options</Link> available in uploader with Box for Salesforce are:

* `folderId` - if the lightning component is on a record page, it defaults to the record folder
* `fileLimit`

<RelatedLinks
  title="RELATED GUIDES"
  items={[
{ label: translate("Install Salesforce SDK"), href: "/guides/tooling/sdks/salesforce", badge: "GUIDE" }
]}
/>
