npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@rdtask/editor

v1.0.2

Published

Core Editor that powers Plane

Readme

@rdtask/editor

Description

The @rdtask/editor package serves as the foundation for our editor system. It provides the base functionality for our other editor packages, but it will not be used directly in any of the projects but only for extending other editors.

Utilities

We provide a wide range of utilities for extending the core itself.

  1. Merging classes and custom styling
  2. Adding new extensions
  3. Adding custom props
  4. Base menu items, and their commands

This allows for extensive customization and flexibility in the Editors created using our editor-core package.

Here's a detailed overview of what's exported

  1. useEditor - A hook that you can use to extend the Plane editor.

    | Prop | Type | Description | | ------------------------- | ---------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------- | | extensions | Extension[] | An array of custom extensions you want to add into the editor to extend it's core features | | editorProps | EditorProps | Extend the editor props by passing in a custom props object | | 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. | | value | html string | The initial content of the editor. | | debouncedUpdatesEnabled | boolean | If 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) => void | This 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") => void | This function is called to update the submission status. | | setShouldShowAlert | (showAlert: boolean) => void | This function is used to show or hide an alert in case of content not being "saved". | | forwardedRef | any | Pass this in whenever you want to control the editor's state from an external component |

  2. useReadOnlyEditor - A hook that can be used to extend a Read Only instance of the core editor.

    | Prop | Type | Description | | -------------- | ------------- | ------------------------------------------------------------------------------------------ | | value | string | The initial content of the editor. | | forwardedRef | any | Pass this in whenever you want to control the editor's state from an external component | | extensions | Extension[] | An array of custom extensions you want to add into the editor to extend it's core features | | editorProps | EditorProps | Extend the editor props by passing in a custom props object |

  3. Items and Commands - H1, H2, H3, task list, quote, code block, etc's methods.

  4. UI Wrappers

  • EditorContainer - Wrap your Editor Container with this to apply base classes and styles.
  • EditorContentWrapper - Use this to get Editor's Content and base menus.
  1. Extending with Custom Styles
const customEditorClassNames = getEditorClassNames({
  noBorder,
  borderOnFocus,
  customClassName,
});

Core features

  • Content Trimming: The Editor’s content is now automatically trimmed of empty line breaks from the start and end before submitting it to the backend. This ensures cleaner, more consistent data.
  • Value Cleaning: The Editor’s value is cleaned at the editor core level, eliminating the need for additional validation before sending from our app. This results in cleaner code and less potential for errors.
  • Turbo Pipeline: Added a turbo pipeline for both dev and build tasks for projects depending on the editor package.

Base extensions included

  • BulletList
  • OrderedList
  • Blockquote
  • Code
  • Gapcursor
  • Link
  • Image
  • Basic Marks
    • Underline
    • TextStyle
    • Color
  • TaskList
  • Markdown
  • Table