AbdulElahGwaith's picture
Upload folder using huggingface_hub
88df9e4 verified
import { useEffect } from 'react'
import { DefaultLayout } from '@/frame/components/DefaultLayout'
import { MarkdownContent } from '@/frame/components/ui/MarkdownContent'
import { Lead } from '@/frame/components/ui/Lead'
import { PermissionsStatement } from '@/frame/components/ui/PermissionsStatement'
import { RestOperation } from './RestOperation'
import { useAutomatedPageContext } from '@/automated-pipelines/components/AutomatedPageContext'
import { Operation } from './types'
import { ClientSideRedirects } from '@/rest/components/ClientSideRedirects'
import { RestRedirect } from '@/rest/components/RestRedirect'
import { Breadcrumbs } from '@/frame/components/page-header/Breadcrumbs'
export type StructuredContentT = {
restOperations: Operation[]
}
export const RestReferencePage = ({ restOperations }: StructuredContentT) => {
const { title, intro, renderedPage, permissions, product } = useAutomatedPageContext()
// Scrollable code blocks in our REST API docs and elsewhere aren't accessible
// via keyboard navigation without setting tabindex="0". But we don't want to set
// this attribute on every `<pre>` code block, only the ones where there are scroll
// bars because the content isn't all visible.
useEffect(() => {
const codeBlocks = document.querySelectorAll<HTMLPreElement>('pre')
for (const codeBlock of codeBlocks) {
if (
codeBlock.scrollWidth > codeBlock.clientWidth ||
codeBlock.scrollHeight > codeBlock.clientHeight
) {
codeBlock.setAttribute('tabindex', '0')
}
}
}, [])
return (
<DefaultLayout>
{/* Doesn't matter *where* this is included because it will
never render anything. It always just return null. */}
<ClientSideRedirects />
<RestRedirect />
<div className="px-3 px-md-6 my-4 container-xl" data-search="article-body">
<div className="d-none d-xl-block my-3 mr-auto width-full">
<Breadcrumbs />
</div>
<h1 id="title-h1" className="mb-3">
{title}
</h1>
{intro && (
<Lead data-testid="lead" data-search="lead">
{intro}
</Lead>
)}
<PermissionsStatement permissions={permissions} product={product} />
{renderedPage && <MarkdownContent className="pt-3 pb-4">{renderedPage}</MarkdownContent>}
{restOperations.length > 0 && (
<MarkdownContent className="pt-3 pb-4">
{restOperations.map((operation) => (
<RestOperation
key={`${operation.title}-${operation.category}-${operation.subcategory}`}
operation={operation}
/>
))}
</MarkdownContent>
)}
</div>
</DefaultLayout>
)
}