Skip to content

Commit

Permalink
doc(sanity): add TS-doc for block content related types
Browse files Browse the repository at this point in the history
  • Loading branch information
skogsmaskin committed Sep 13, 2023
1 parent 12687ed commit 24e35e8
Show file tree
Hide file tree
Showing 11 changed files with 472 additions and 74 deletions.
26 changes: 26 additions & 0 deletions packages/@sanity/types/src/schema/definition/type/block.ts
Original file line number Diff line number Diff line change
Expand Up @@ -54,8 +54,11 @@ export interface BlockDecoratorDefinition {

/**
* Schema definition for a text block style.
* A text block may have a block style like 'header', 'normal', 'lead'
* attached to it, which is stored on the `.style` property for that block.
*
* @public
* @remarks The first defined style will become the default style.´´
* @example The default set of styles
* ```ts
* {
Expand All @@ -79,6 +82,29 @@ export interface BlockDecoratorDefinition {
* ]
* }
* ```
* @example Example of defining a block type with custom styles and render components.
* ```ts
* defineArrayMember({
* type: 'block',
* styles: [
* {
* title: 'Paragraph',
* value: 'paragraph',
* component: ParagraphStyle,
* },
* {
* title: 'Lead',
* value: 'lead',
* component: LeadStyle,
* },
* {
* title: 'Heading',
* value: 'heading',
* component: HeadingStyle,
* },
* ],
* })
* ```
*/
export interface BlockStyleDefinition {
title: string
Expand Down
2 changes: 1 addition & 1 deletion packages/sanity/src/core/components/previews/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ export type PreviewLayoutKey = GeneralPreviewLayoutKey | PortableTextPreviewLayo

/**
* @hidden
* @beta
* @public
*/
export interface PreviewMediaDimensions {
aspect?: number
Expand Down
1 change: 0 additions & 1 deletion packages/sanity/src/core/form/FormBuilderContext.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ import {createContext} from 'react'
import {DocumentFieldAction} from '../config'
import {PatchChannel} from './patch'
import {
FormBuilderArrayFunctionComponent,
FormBuilderCustomMarkersComponent,
FormBuilderFilterFieldFn,
FormBuilderMarkersComponent,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -45,10 +45,16 @@ export interface PortableTextMemberItem {
}

/**
* The root Portable Text Input component
* Input component for editing block content
* ({@link https://github.com/portabletext/portabletext | Portable Text}) in the Sanity Studio.
*
* @hidden
* @beta
* Supports multi-user real-time block content editing on larger documents.
*
* This component can be configured and customized extensively.
* {@link https://www.sanity.io/docs/portable-text-features | Go to the documentation for more details}.
*
* @public
* @param props - {@link PortableTextInputProps} component props.
*/
export function PortableTextInput(props: PortableTextInputProps) {
const {
Expand Down
31 changes: 14 additions & 17 deletions packages/sanity/src/core/form/types/_transitional.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,18 +14,20 @@ import {FieldProps} from './fieldProps'
import {ItemProps} from './itemProps'

/**
* Export `PortableTextMarker` so it can be used to build custom Portable Text markers.
* Function for rendering custom block markers
*
* @beta
* @public
* @hidden
* @deprecated - use `renderBlock`, `renderInlineBlock`, `renderAnnotation` interfaces instead
* @deprecated use `renderBlock`, `renderInlineBlock`, `renderAnnotation` interfaces instead
*/
export type RenderCustomMarkers = (markers: PortableTextMarker[]) => React.ReactNode

/**
* Props for rendering block actions
*
* @public
* @hidden
* @beta
* @deprecated use `renderBlock`, `renderInlineBlock`, `renderAnnotation` interfaces instead
*/
export interface RenderBlockActionsProps {
block: PortableTextBlock
Expand All @@ -36,18 +38,20 @@ export interface RenderBlockActionsProps {
}

/**
* Function for rendering custom block actions
*
* @public
* @hidden
* @beta
* @deprecated use `renderBlock`, `renderInlineBlock`, `renderAnnotation` interfaces instead
*/
export type RenderBlockActionsCallback = (props: RenderBlockActionsProps) => React.ReactNode

/**
* A generic marker for attaching metadata to specific nodes of the Portable Text input.
*
* @beta
* @public
* @hidden
* @deprecated - use `renderBlock`, `renderInlineBlock`, `renderAnnotation` interfaces instead
* @deprecated use `renderBlock`, `renderInlineBlock`, `renderAnnotation` interfaces instead
* @param type - a type name for this marker
* @param data - some data connected to this marker
* @param path - the path to the Portable Text content connected to this marker
Expand All @@ -59,18 +63,11 @@ export interface PortableTextMarker {
}

/**
* Component for rendering custom block markers
*
* @public
* @hidden
* @beta
*/
export type FormBuilderArrayFunctionComponent = React.ComponentType<
ArrayInputFunctionsProps<unknown, ArraySchemaType>
>

/**
*
* @hidden
* @beta
* @deprecated use `renderBlock`, `renderInlineBlock`, `renderAnnotation` interfaces instead
*/
export type FormBuilderCustomMarkersComponent = React.ComponentType<{markers: PortableTextMarker[]}>

Expand Down
Loading

0 comments on commit 24e35e8

Please sign in to comment.