2.0.0 • Published 1 year ago

jtdwn-lite-text-editor v2.0.0

Weekly downloads
-
License
-
Repository
-
Last release
1 year ago

jtdwn-lite-text-editor

Description

The jtdwn-lite-text-editor package extends from the editor-core package, inheriting its base functionality while adding its own unique features of Custom control over Enter key, etc.

Key Features

  • Exported Components: There are two components exported from the Lite text editor (with and without Ref), you can choose to use the withRef instance whenever you want to control the Editor’s state via a side effect of some external action from within the application code.

    LiteTextEditor & LiteTextEditorWithRef

  • Read Only Editor Instances: We have added a really light weight Read Only Editor instance for the Lite editor types (with and without Ref) LiteReadOnlyEditor &LiteReadOnlyEditorWithRef

LiteTextEditor

PropTypeDescription
uploadFile(file: File) => Promise<string>A function that handles file upload. It takes a file as input and handles the process of uploading that file.
deleteFile(assetUrlWithWorkspaceId: string) => Promise<any>A function that handles deleting an image. It takes the asset url from your bucket and handles the process of deleting that image.
valuehtml stringThe initial content of the editor.
onEnterKeyPress(e) => voidThe event that happens on Enter key press
debouncedUpdatesEnabledbooleanIf set to true, the onChange event handler is debounced, meaning it will only be invoked after the specified delay (default 1500ms) once the user has stopped typing.
onChange(json: any, html: string) => voidThis function is invoked whenever the content of the editor changes. It is passed the new content in both JSON and HTML formats.
setIsSubmitting(isSubmitting: "submitting" \| "submitted" \| "saved") => voidThis function is called to update the submission status.
setShouldShowAlert(showAlert: boolean) => voidThis function is used to show or hide an alert incase of content not being "saved".
noBorderbooleanIf set to true, the editor will not have a border.
borderOnFocusbooleanIf set to true, the editor will show a border when it is focused.
customClassNamestringThis is a custom CSS class that can be applied to the editor.
editorContentCustomClassNamesstringThis is a custom CSS class that can be applied to the editor content.

Usage

  1. Here is an example of how to use the RichTextEditor component
<LiteTextEditor
  onEnterKeyPress={handleSubmit(handleCommentUpdate)}
  uploadFile={fileService.getUploadFileFunction(workspaceSlug)}
  deleteFile={fileService.deleteImage}
  value={value}
  debouncedUpdatesEnabled={false}
  customClassName="min-h-[50px] p-3 shadow-sm"
  onChange={(comment_json: Object, comment_html: string) => {
    onChange(comment_html);
  }}
/>
  1. Example of how to use the LiteTextEditorWithRef component
const editorRef = useRef<any>(null);

// can use it to set the editor's value
editorRef.current?.setEditorValue(`${watch("description_html")}`);

// can use it to clear the editor
editorRef?.current?.clearEditor();

return (
  <LiteTextEditorWithRef
    onEnterKeyPress={handleSubmit(handleCommentUpdate)}
    uploadFile={fileService.getUploadFileFunction(workspaceSlug)}
    deleteFile={fileService.deleteImage}
    ref={editorRef}
    value={value}
    debouncedUpdatesEnabled={false}
    customClassName="min-h-[50px] p-3 shadow-sm"
    onChange={(comment_json: Object, comment_html: string) => {
      onChange(comment_html);
    }}
  />
);

LiteReadOnlyEditor

PropTypeDescription
valuehtml stringThe initial content of the editor.
noBorderbooleanIf set to true, the editor will not have a border.
borderOnFocusbooleanIf set to true, the editor will show a border when it is focused.
customClassNamestringThis is a custom CSS class that can be applied to the editor.
editorContentCustomClassNamesstringThis is a custom CSS class that can be applied to the editor content.

Usage

Here is an example of how to use the RichReadOnlyEditor component

<LiteReadOnlyEditor
  value={comment.comment_html}
  customClassName="text-xs border border-custom-border-200 bg-custom-background-100"
/>
2.0.0

1 year ago

0.16.0

1 year ago