Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feat/UI useredit panel #22

Merged
merged 93 commits into from
Dec 13, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
93 commits
Select commit Hold shift + click to select a range
2b4c08c
wip: initial draft implementation of userEditPanel
olzzon Oct 14, 2024
c1e8e10
wip: userEditPanel grouping
olzzon Oct 15, 2024
fb54ad2
wip: userEditPanel cleanup remove schema as it's replaces by schemas
olzzon Oct 16, 2024
7fd9bf1
wip: userEditPanel styling and use <select> for list
olzzon Oct 16, 2024
040dbc4
wip: userEditPanel - make groupType optional to allow empty slots
olzzon Oct 16, 2024
d49b265
wip: userEditPanel - convert to FC
olzzon Oct 16, 2024
d93d0a9
wip: userEditPanel - uncomment context menu
olzzon Oct 17, 2024
9cbc324
wip: UserEditPanel - Add DefaultUserOperationsTypes for revert button…
olzzon Oct 17, 2024
0643ff3
wip: UserEditPanel - Default revert button on panel
olzzon Oct 17, 2024
9d46129
wip: UserEditPanel - tracker on part and segment
olzzon Oct 17, 2024
27a2680
wip: UserEditPanel - only render Segment or Part in panel
olzzon Oct 21, 2024
298d10c
wip: UserEditPanel - initial header for part and segment
olzzon Oct 21, 2024
526211e
wip: UserEditPanel - comment for the usage of getTimePosition
olzzon Oct 21, 2024
a673847
wip: UserEditPanel - add Icons in header
olzzon Oct 21, 2024
5324fa3
wip: UserEditPanel - add button type in UserEditingDefinitions
olzzon Oct 21, 2024
c8b7e79
wip: UserEditPanel - rename revert button to "Revert Changes"
olzzon Oct 21, 2024
a1fc06b
wip: UserEditPanel - add support for SVG icons in grouping (e.g for s…
olzzon Oct 22, 2024
c76ec35
wip: UserEditPanel - center revert button
olzzon Oct 22, 2024
c6d0bf5
wip: Renaming UserEditPanel to PropertiesPanel
olzzon Oct 22, 2024
163cb46
wip: UI selection - Context for SelectedElements
olzzon Oct 23, 2024
e037d59
wip: UI selection - refactor from useState() to useReducer()
olzzon Oct 24, 2024
7fe136f
wip: UI selection - use type for SelectedElement
olzzon Oct 24, 2024
061d61f
wip: UI selection -Segment not updating upon selection
olzzon Oct 24, 2024
2a252e8
feat: unit tests for SelectedElementsContext
olzzon Oct 24, 2024
1710bb4
wip: UI selection - add isSelected to withSegmentTiming
olzzon Oct 25, 2024
c00b2fd
wip: fix props withSelection
olzzon Oct 25, 2024
3a3b9ff
wip: fix props withSelection
olzzon Oct 25, 2024
02b9a41
wip: remove componentDidUpdate - leftover from previous debugging
olzzon Oct 25, 2024
030163e
fix: added listSelectedElements() instead of exposing the selectedEle…
olzzon Oct 25, 2024
ad46b36
fix: add assertNever() to selectionReducer
olzzon Oct 25, 2024
e760534
fix: remove id and use ElementId as reference in context provider
olzzon Oct 25, 2024
73753f8
fix: clean up isSelected should parse boolean not function as props
olzzon Oct 25, 2024
14e03fe
chore: update package with @testing-library/react
olzzon Oct 25, 2024
cb43189
fix: tests for SelecedElementsContext updated and type fixed
olzzon Oct 25, 2024
875a438
fix: listSelectedElements is af function not an array
olzzon Oct 25, 2024
382179c
wip: implement useSelection in PropertiesPanel
olzzon Oct 25, 2024
3222f65
wip: useSelection on Parts
olzzon Oct 25, 2024
ef2c47d
fix: missing rundown id in propertiespanel actions
olzzon Oct 25, 2024
2ad708a
feat: add enabling of userediting in settings
olzzon Oct 31, 2024
7a79afa
feat: doubleclick on part selection for properties panel
olzzon Oct 31, 2024
2169357
fix: properties panel crash when no selection was made
olzzon Oct 31, 2024
a6a431c
feat: segment selection
olzzon Oct 31, 2024
8dc7700
feat: dbl click anywhere in segment header to select properties
olzzon Oct 31, 2024
48521c6
feat: select part by double clicking a piece
olzzon Oct 31, 2024
8220392
feat: properties panel commit button for pending changes
olzzon Oct 31, 2024
3aaea87
feat: select/deselect an element - fix flickering upen commit changes
olzzon Nov 1, 2024
07bd3ec
fix: render all userEditOperations when part is selected
olzzon Nov 1, 2024
ba03df0
feat: move Properties panel out of notification center logic
olzzon Nov 4, 2024
52a0d54
feat: use context.consumer instead of wrapping
olzzon Nov 4, 2024
8bdc2cd
feat: refactor userEditing structure
olzzon Nov 6, 2024
662681e
feat: properties panel with refactored data structure.
olzzon Nov 6, 2024
091af40
feat: Schema selection implemented in commit button logic
olzzon Nov 6, 2024
4d58ce8
feat: implement Layer colors in group selectors
olzzon Nov 6, 2024
4ef35fd
feat: only parse the selected source on useraction commit
olzzon Nov 7, 2024
525cd59
feat: simplify structure for userEditing source
olzzon Nov 7, 2024
3a5bda0
fix: rerender group selection when selecting new part
olzzon Nov 7, 2024
5e547ce
fix: read the SourceLayerType into UserEditingDefinition
olzzon Nov 7, 2024
3978c2b
feat: selected element indicator
olzzon Nov 7, 2024
6470d43
feat: properties panel styling - is edited indication
olzzon Nov 8, 2024
b674e2d
wip: add close propterties icon (sketch)
olzzon Nov 8, 2024
4bd57d6
wip: properties panel css dim commit+revert when not active
olzzon Nov 8, 2024
cb2455b
wip: properties panel clean up first iteration selector
olzzon Nov 8, 2024
b4d75dd
wip: properties panel add close upper right
olzzon Nov 8, 2024
15d77e8
fix: crash UI - remove transiongroup
olzzon Nov 8, 2024
7b65130
feat: properties panel animate in and shrink rundown view
olzzon Nov 8, 2024
8666da3
fix: cleanup using notificationpanel for properties panel
olzzon Nov 8, 2024
631ef97
wip: properties panel, rightbar icon color
olzzon Nov 8, 2024
ad78549
fix: re-run only if part.segmentId has changed
olzzon Nov 9, 2024
d3e0ca7
wip: tests for properties panel
olzzon Nov 9, 2024
5fe974f
wip: properties panel tests - useFaketimers and implement mock useTra…
olzzon Nov 11, 2024
b86bc21
wip: properties panel - element selection styling
olzzon Nov 11, 2024
e6d4c94
wip: properties panel styling edit pencil icon
olzzon Nov 11, 2024
e0969ef
wip: properties panel close when notification is open
olzzon Nov 12, 2024
6a10475
wip: properties panel selection glow on segment header
olzzon Nov 12, 2024
61c73a0
feat: StyledSchemaFormInPlace schema component
olzzon Nov 13, 2024
958d8e3
fix: Properties panel - StyledSchemaFormInPlace schema for normal form
olzzon Nov 13, 2024
7f5fa09
feat: Properties panel is edited pencil styling
olzzon Nov 13, 2024
d623cc6
feat: Properties header styling
olzzon Nov 13, 2024
75b1930
wip: Properties tests - more mocking to get correct rendering in test…
olzzon Nov 13, 2024
91dae54
chore: fix unit tests
mint-dewit Nov 21, 2024
77bf227
feat: refactor form action to properties field
mint-dewit Nov 27, 2024
aa35b1b
chore: update styles
mint-dewit Dec 2, 2024
ea2fb4a
chore: add actions back into property panel
mint-dewit Dec 2, 2024
a671baa
chore: support translations for properties panel
mint-dewit Dec 5, 2024
53488d2
chore: fix some build issues
mint-dewit Dec 5, 2024
ffdde73
Merge pull request #38 from bbc/chore/ui-useredit-properties
mint-dewit Dec 5, 2024
80ae9d8
feat: allow editing piece properties
mint-dewit Dec 6, 2024
50d869e
chore: various review comments
mint-dewit Dec 10, 2024
e4cf90e
chore: fix tests
mint-dewit Dec 11, 2024
91e9431
chore: merge bbc-release52 into feat/ui-useredit-panel
mint-dewit Dec 11, 2024
8f9df89
chore: merge bbc-release52 into feat/useredit-panel
mint-dewit Dec 12, 2024
dedebee
chore: remove unused parameter
mint-dewit Dec 12, 2024
287f007
chore: removed commented styles
mint-dewit Dec 13, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions meteor/server/api/rest/v1/typeConversion.ts
Original file line number Diff line number Diff line change
Expand Up @@ -367,6 +367,7 @@ export function studioSettingsFrom(apiStudioSettings: APIStudioSettings): Comple
enableQuickLoop: apiStudioSettings.enableQuickLoop,
forceQuickLoopAutoNext: forceQuickLoopAutoNextFrom(apiStudioSettings.forceQuickLoopAutoNext),
fallbackPartDuration: apiStudioSettings.fallbackPartDuration ?? DEFAULT_FALLBACK_PART_DURATION,
enableUserEdits: apiStudioSettings.enableUserEdits,
allowAdlibTestingSegment: apiStudioSettings.allowAdlibTestingSegment,
allowHold: apiStudioSettings.allowHold ?? true, // Backwards compatible
allowPieceDirectPlay: apiStudioSettings.allowPieceDirectPlay ?? true, // Backwards compatible
Expand All @@ -390,6 +391,7 @@ export function APIStudioSettingsFrom(settings: IStudioSettings): Complete<APISt
enableQuickLoop: settings.enableQuickLoop,
forceQuickLoopAutoNext: APIForceQuickLoopAutoNextFrom(settings.forceQuickLoopAutoNext),
fallbackPartDuration: settings.fallbackPartDuration,
enableUserEdits: settings.enableUserEdits,
allowAdlibTestingSegment: settings.allowAdlibTestingSegment,
allowHold: settings.allowHold,
allowPieceDirectPlay: settings.allowPieceDirectPlay,
Expand Down
1 change: 1 addition & 0 deletions meteor/server/lib/rest/v1/studios.ts
Original file line number Diff line number Diff line change
Expand Up @@ -216,6 +216,7 @@ export interface APIStudioSettings {
forceQuickLoopAutoNext?: 'disabled' | 'enabled_when_valid_duration' | 'enabled_forcing_min_duration'
minimumTakeSpan?: number
fallbackPartDuration?: number
enableUserEdits?: boolean
allowAdlibTestingSegment?: boolean
allowHold?: boolean
allowPieceDirectPlay?: boolean
Expand Down
8 changes: 7 additions & 1 deletion packages/blueprints-integration/src/documents/part.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import type { UserEditingDefinition } from '../userEditing'
import { UserEditingDefinition, UserEditingProperties } from '../userEditing'
import type { NoteSeverity } from '../lib'
import type { ITranslatableMessage } from '../translations'

Expand Down Expand Up @@ -88,6 +88,12 @@ export interface IBlueprintMutatablePart<TPrivateData = unknown, TPublicData = u
* User editing definitions for this part
*/
userEditOperations?: UserEditingDefinition[]

/**
* Properties that are user editable from the properties panel in the Sofie UI, if the user saves changes to these
* it will trigger a user edit operation of type DefaultUserOperationEditProperties
*/
userEditProperties?: UserEditingProperties
}

export interface HackPartMediaObjectSubscription {
Expand Down
8 changes: 7 additions & 1 deletion packages/blueprints-integration/src/documents/piece.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import type { UserEditingDefinition } from '../userEditing'
import { UserEditingDefinition, UserEditingProperties } from '../userEditing'
import type { IBlueprintPieceGeneric } from './pieceGeneric'

/** Special types of pieces. Some are not always used in all circumstances */
Expand Down Expand Up @@ -36,6 +36,12 @@ export interface IBlueprintPiece<TPrivateData = unknown, TPublicData = unknown>
*/
userEditOperations?: UserEditingDefinition[]

/**
* Properties that are user editable from the properties panel in the Sofie UI, if the user saves changes to these
* it will trigger a user edit operation of type DefaultUserOperationEditProperties
*/
userEditProperties?: UserEditingProperties

/**
* Whether to stop this piece before the 'keepalive' period of the part
*/
Expand Down
8 changes: 7 additions & 1 deletion packages/blueprints-integration/src/documents/segment.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import type { UserEditingDefinition } from '../userEditing'
import { UserEditingDefinition, UserEditingProperties } from '../userEditing'

export enum SegmentDisplayMode {
Timeline = 'timeline',
Expand Down Expand Up @@ -52,6 +52,12 @@ export interface IBlueprintSegment<TPrivateData = unknown, TPublicData = unknown
* User editing definitions for this segment
*/
userEditOperations?: UserEditingDefinition[]

/**
* Properties that are user editable from the properties panel in the Sofie UI, if the user saves changes to these
* it will trigger a user edit operation of type DefaultUserOperationEditProperties
*/
userEditProperties?: UserEditingProperties
}
/** The Segment sent from Core */
export interface IBlueprintSegmentDB<TPrivateData = unknown, TPublicData = unknown>
Expand Down
34 changes: 32 additions & 2 deletions packages/blueprints-integration/src/ingest.ts
Original file line number Diff line number Diff line change
Expand Up @@ -124,11 +124,41 @@ export interface UserOperationTarget {
pieceExternalId: string | undefined
}

export type DefaultUserOperations = {
id: '__sofie-move-segment' // Future: define properly
export enum DefaultUserOperationsTypes {
REVERT_SEGMENT = '__sofie-revert-segment',
REVERT_PART = '__sofie-revert-part',
REVERT_RUNDOWN = '__sofie-revert-rundown',
UPDATE_PROPS = '__sofie-update-props',
}

export interface DefaultUserOperationRevertRundown {
id: DefaultUserOperationsTypes.REVERT_RUNDOWN
payload: Record<string, never>
}

export interface DefaultUserOperationRevertSegment {
id: DefaultUserOperationsTypes.REVERT_SEGMENT
payload: Record<string, never>
}

export interface DefaultUserOperationRevertPart {
id: DefaultUserOperationsTypes.REVERT_PART
}

export interface DefaultUserOperationEditProperties {
id: DefaultUserOperationsTypes.UPDATE_PROPS
payload: {
pieceTypeProperties: { type: string; value: Record<string, any> }
globalProperties: Record<string, any>
}
}

export type DefaultUserOperations =
| DefaultUserOperationRevertRundown
| DefaultUserOperationRevertSegment
| DefaultUserOperationRevertPart
| DefaultUserOperationEditProperties

export interface UserOperationChange<TCustomBlueprintOperations extends { id: string } = never> {
/** Indicate that this change is from user operations */
source: IngestChangeType.User
Expand Down
56 changes: 53 additions & 3 deletions packages/blueprints-integration/src/userEditing.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import type { JSONBlob } from '@sofie-automation/shared-lib/dist/lib/JSONBlob'
import type { ITranslatableMessage } from './translations'
import type { JSONSchema } from '@sofie-automation/shared-lib/dist/lib/JSONSchemaTypes'
import { JSONSchema } from '@sofie-automation/shared-lib/dist/lib/JSONSchemaTypes'
import { SourceLayerType } from './content'

/**
* Description of a user performed editing operation allowed on an document
Expand All @@ -16,8 +17,10 @@ export interface UserEditingDefinitionAction {
id: string
/** Label to show to the user for this operation */
label: ITranslatableMessage
/** Icon to show to when this action is 'active' */
/** Icon to show when this action is 'active' */
svgIcon?: string
/** Icon to show when this action is 'disabled' */
svgIconInactive?: string
/** Whether this action should be indicated as being active */
isActive?: boolean
}
Expand All @@ -40,6 +43,53 @@ export interface UserEditingDefinitionForm {
export enum UserEditingType {
/** Action */
ACTION = 'action',
/** Form of selections */
/** Form */
FORM = 'form',
}

export interface UserEditingSourceLayer {
sourceLayerLabel: string
sourceLayerType: SourceLayerType
schema: JSONBlob<JSONSchema>
defaultValue?: Record<string, any>
}

export interface UserEditingProperties {
/**
* These properties are dependent on the (primary) piece type, the user will get the option
* to select the type of piece (from the SourceLayerTypes i.e. Camera or Split etc.) and then
* be presented the corresponding form
*
* example:
* {
* schema: {
* camera: '{ "type": "object", "properties": { "input": { "type": "number" } } }',
* split: '{ "type": "object", ... }',
* },
* currentValue: {
* type: 'camera',
* value: {
* input: 3
* },
* }
* }
*/
pieceTypeProperties?: {
schema: Record<string, UserEditingSourceLayer>
currentValue: { type: string; value: Record<string, any> }
}

/**
* These are properties that are available to edit regardless of the piece type, examples
* could be whether it an element is locked from NRCS updates
*
* if you do not want the piece type to be changed, then use only this field.
*/
globalProperties?: { schema: JSONBlob<JSONSchema>; currentValue: Record<string, any> }

/**
* A list of id's of operations to be exposed on the properties panel as buttons. These operations
* must be available on the element
*/
operations?: UserEditingDefinitionAction[]
}
8 changes: 7 additions & 1 deletion packages/corelib/src/dataModel/Part.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { ITranslatableMessage } from '../TranslatableMessage'
import { PartId, RundownId, SegmentId } from './Ids'
import { PartNote } from './Notes'
import { ReadonlyDeep } from 'type-fest'
import { CoreUserEditingDefinition } from './UserEditingDefinitions'
import { CoreUserEditingDefinition, CoreUserEditingProperties } from './UserEditingDefinitions'

export interface PartInvalidReason {
message: ITranslatableMessage
Expand Down Expand Up @@ -41,6 +41,12 @@ export interface DBPart extends Omit<IBlueprintPart, 'userEditOperations'> {
* User editing definitions for this part
*/
userEditOperations?: CoreUserEditingDefinition[]

/**
* Properties that are user editable from the properties panel in the Sofie UI, if the user saves changes to these
* it will trigger a user edit operation of type DefaultUserOperationEditProperties
*/
userEditProperties?: CoreUserEditingProperties
}

export function isPartPlayable(part: Pick<ReadonlyDeep<DBPart>, 'invalid' | 'floated'>): boolean {
Expand Down
12 changes: 10 additions & 2 deletions packages/corelib/src/dataModel/Piece.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import {
} from '@sofie-automation/blueprints-integration'
import { ProtectedString, protectString, unprotectString } from '../protectedString'
import { PieceId, RundownId, SegmentId, PartId } from './Ids'
import { CoreUserEditingDefinition } from './UserEditingDefinitions'
import { CoreUserEditingDefinition, CoreUserEditingProperties } from './UserEditingDefinitions'

/** A generic list of playback availability statuses for a Piece */
export enum PieceStatusCode {
Expand Down Expand Up @@ -50,7 +50,9 @@ export interface PieceGeneric extends Omit<IBlueprintPieceGeneric, 'content'> {
/** Stringified timelineObjects */
timelineObjectsString: PieceTimelineObjectsBlob
}
export interface Piece extends PieceGeneric, Omit<IBlueprintPieceDB, '_id' | 'content' | 'userEditOperations'> {
export interface Piece
extends PieceGeneric,
Omit<IBlueprintPieceDB, '_id' | 'content' | 'userEditOperations' | 'userEditProperties'> {
/**
* This is the id of the rundown this piece starts playing in.
* Currently this is the only rundown the piece could be playing in
Expand All @@ -77,6 +79,12 @@ export interface Piece extends PieceGeneric, Omit<IBlueprintPieceDB, '_id' | 'co
* User editing definitions for this piece
*/
userEditOperations?: CoreUserEditingDefinition[]

/**
* Properties that are user editable from the properties panel in the Sofie UI, if the user saves changes to these
* it will trigger a user edit operation of type DefaultUserOperationEditProperties
*/
userEditProperties?: CoreUserEditingProperties
}

export type PieceTimelineObjectsBlob = ProtectedString<'PieceTimelineObjectsBlob'>
Expand Down
8 changes: 7 additions & 1 deletion packages/corelib/src/dataModel/Segment.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { SegmentDisplayMode, SegmentTimingInfo } from '@sofie-automation/blueprints-integration'
import { SegmentId, RundownId } from './Ids'
import { SegmentNote } from './Notes'
import { CoreUserEditingDefinition } from './UserEditingDefinitions'
import { CoreUserEditingDefinition, CoreUserEditingProperties } from './UserEditingDefinitions'

export enum SegmentOrphanedReason {
/** Segment is deleted from the NRCS but we still need it */
Expand Down Expand Up @@ -51,4 +51,10 @@ export interface DBSegment {
* User editing definitions for this segment
*/
userEditOperations?: CoreUserEditingDefinition[]

/**
* Properties that are user editable from the properties panel in the Sofie UI, if the user saves changes to these
* it will trigger a user edit operation of type DefaultUserOperationEditProperties
*/
userEditProperties?: CoreUserEditingProperties
}
59 changes: 57 additions & 2 deletions packages/corelib/src/dataModel/UserEditingDefinitions.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,9 @@
import type { UserEditingType, JSONBlob, JSONSchema } from '@sofie-automation/blueprints-integration'
import type {
UserEditingType,
JSONBlob,
JSONSchema,
UserEditingSourceLayer,
} from '@sofie-automation/blueprints-integration'
import type { ITranslatableMessage } from '../TranslatableMessage'

export type CoreUserEditingDefinition = CoreUserEditingDefinitionAction | CoreUserEditingDefinitionForm
Expand All @@ -9,12 +14,17 @@ export interface CoreUserEditingDefinitionAction {
id: string
/** Label to show to the user for this operation */
label: ITranslatableMessage
/** Icon to show to when this action is 'active' */
/** Icon to show when this action is 'active' */
svgIcon?: string
/** Icon to show when this action is 'disabled' */
svgIconInactive?: string
/** Whether this action should be indicated as being active */
isActive?: boolean
}

/**
* A simple form based operation
*/
export interface CoreUserEditingDefinitionForm {
type: UserEditingType.FORM
/** Id of this operation */
Expand All @@ -28,3 +38,48 @@ export interface CoreUserEditingDefinitionForm {
/** Translation namespaces to use when rendering this form */
translationNamespaces: string[]
}

export interface CoreUserEditingProperties {
/**
* These properties are dependent on the (primary) piece type, the user will get the option
* to select the type of piece (from the SourceLayerTypes i.e. Camera or Split etc.) and then
* be presented the corresponding form
*
* example:
* {
* schema: {
* camera: '{ "type": "object", "properties": { "input": { "type": "number" } } }',
* split: '{ "type": "object", ... }',
* },
* currentValue: {
* type: 'camera',
* value: {
* input: 3
* },
* }
* }
*/
pieceTypeProperties?: {
schema: Record<string, UserEditingSourceLayer>
currentValue: { type: string; value: Record<string, any> }
}

/**
* These are properties that are available to edit regardless of the piece type, examples
* could be whether it an element is locked from NRCS updates
*
* if you do not want the piece type to be changed, then use only this field.
*/
globalProperties?: { schema: JSONBlob<JSONSchema>; currentValue: Record<string, any> }

/**
* A list of id's of operations to be exposed on the properties panel as buttons. These operations
* must be available on the element
*
* note - perhaps these should have their own full definitions?
*/
operations?: CoreUserEditingDefinitionAction[]

/** Translation namespaces to use when rendering this form */
translationNamespaces: string[]
}
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,12 @@ If an integer property, whether to treat it as zero-based
### `ui:displayType`

Override the presentation with a special mode.
Currently only valid for string properties. Valid values are 'json'.

Currently only valid for:

- object properties. Valid values are 'json'.
- string properties. Valid values are 'base64-image'.
- boolean properties. Valid values are 'switch'.

### `tsEnumNames`

Expand Down
Loading
Loading