Skip to content

Commit

Permalink
feat: properly handle isDisabled props within RichText, Markdown, Sin…
Browse files Browse the repository at this point in the history
…gleLine and MultipleLine editos
  • Loading branch information
bgutsol committed Dec 9, 2024
1 parent b8b66f9 commit 7907efd
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 9 deletions.
13 changes: 7 additions & 6 deletions packages/markdown/src/MarkdownEditor.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -42,11 +42,11 @@ export interface MarkdownEditorProps {

previewComponents?: PreviewComponents;
onReady?: Function;
isDisabled?: boolean;
}

export function MarkdownEditor(
props: MarkdownEditorProps & {
disabled: boolean;
value: string | null | undefined;
saveValueToSDK: Function;
externalReset?: number;
Expand Down Expand Up @@ -78,9 +78,9 @@ export function MarkdownEditor(

React.useEffect(() => {
if (editor) {
editor.setReadOnly(props.disabled);
editor.setReadOnly(!!props.isDisabled);
}
}, [editor, props.disabled]);
}, [editor, props.isDisabled]);

React.useEffect(() => {
// Received new props from external
Expand All @@ -90,7 +90,7 @@ export function MarkdownEditor(
}
}, [props.value, props.externalReset, editor]);

const isActionDisabled = editor === null || props.disabled || selectedTab !== 'editor';
const isActionDisabled = editor === null || props.isDisabled || selectedTab !== 'editor';

const direction = props.sdk.locales.direction[props.sdk.field.locale] ?? 'ltr';

Expand Down Expand Up @@ -126,7 +126,7 @@ export function MarkdownEditor(
direction={direction}
onReady={(editor) => {
editor.setContent(props.value ?? '');
editor.setReadOnly(props.disabled);
editor.setReadOnly(!!props.isDisabled);
setEditor(editor);
editor.events.onChange((value: string) => {
// Trim empty lines
Expand Down Expand Up @@ -161,12 +161,13 @@ export function MarkdownEditorConnected(props: MarkdownEditorProps) {
debounce={300}
field={props.sdk.field}
isInitiallyDisabled={props.isInitiallyDisabled}
isDisabled={props.isDisabled}
>
{({ value, disabled, setValue, externalReset }) => (
<MarkdownEditor
{...props}
value={value}
disabled={disabled}
isDisabled={disabled}
saveValueToSDK={setValue}
externalReset={externalReset}
/>
Expand Down
10 changes: 8 additions & 2 deletions packages/multiple-line/src/MultipleLineEditor.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -32,10 +32,12 @@ export interface MultipleLineEditorProps {
* sdk.locales
*/
locales: LocalesAPI;

isDisabled?: boolean;
}

export function MultipleLineEditor(props: MultipleLineEditorProps) {
const { field, locales, isInitiallyDisabled, withCharValidation } = props;
const { field, locales, isInitiallyDisabled, withCharValidation, isDisabled } = props;

const constraints = ConstraintsUtils.fromFieldValidations(
field.validations,
Expand All @@ -45,7 +47,11 @@ export function MultipleLineEditor(props: MultipleLineEditorProps) {
const direction = locales.direction[field.locale] || 'ltr';

return (
<FieldConnector<string> field={field} isInitiallyDisabled={isInitiallyDisabled}>
<FieldConnector<string>
field={field}
isInitiallyDisabled={isInitiallyDisabled}
isDisabled={isDisabled}
>
{({ errors, disabled, value, setValue }) => {
return (
<div data-test-id="multiple-line-editor">
Expand Down
11 changes: 10 additions & 1 deletion packages/rich-text/src/RichTextEditor.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -113,7 +113,15 @@ export const ConnectedRichTextEditor = (props: ConnectedRichTextProps) => {
};

const RichTextEditor = (props: RichTextProps) => {
const { sdk, isInitiallyDisabled, onAction, restrictedMarks, onChange, ...otherProps } = props;
const {
sdk,
isInitiallyDisabled,
onAction,
restrictedMarks,
onChange,
isDisabled,
...otherProps
} = props;
const isEmptyValue = React.useCallback(
(value) => !value || deepEquals(value, Contentful.EMPTY_DOCUMENT),
[]
Expand All @@ -132,6 +140,7 @@ const RichTextEditor = (props: RichTextProps) => {
field={sdk.field}
isInitiallyDisabled={isInitiallyDisabled}
isEmptyValue={isEmptyValue}
isDisabled={isDisabled}
>
{({ lastRemoteValue, disabled, setValue }) => (
<ConnectedRichTextEditor
Expand Down

0 comments on commit 7907efd

Please sign in to comment.