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

@serlo/editor

v0.20.2

Published

This is an early version of the [Serlo Editor](https://de.serlo.org/editor). Be aware that we are actively working on this package and thus there will be breaking changes before v1 is reached. The repository [serlo/serlo-editor-for-edusharing](https://git

Downloads

346

Readme

Serlo Editor

This is an early version of the Serlo Editor. Be aware that we are actively working on this package and thus there will be breaking changes before v1 is reached. The repository serlo/serlo-editor-for-edusharing shows an example of how this package can be used in production.

If you are not using React, consider using the Serlo Editor as a web component.

Using the Serlo Editor

Installation

In your React project

yarn add @serlo/editor

Usage

You can see a complete working example of the usage here.

import { SerloEditor, SerloEditorProps } from '@serlo/editor'

type InitialState = SerloEditorProps['initialState']

function MyCustomSerloEditor({ initialState }: { initialState: InitialState }) {
  return (
    <SerloEditor
      initialState={initialState}
      editorVariant="edusharing"
      onChange={(newState) => {
        console.log(`New state: `, newState)
      }}
    >
      {(editor) => (
        {/* Optionally configure plugins or i18n strings via the editor object */}
        <div>
          {/* Renders the actual editor content */}
          {editor.element}
        </div>
      )}
    </SerloEditor>
  )
}

See below for the current API specification.

Current Editor package API

1. SerloEditor, type SerloEditorProps

  • Why Exported/How Used: SerloEditor is the core component of the @serlo/editor package, providing the main editor functionality. It's exported to allow users to embed the editor into their applications.
  • Long-Term Support: Will stay
  • Needs Change?: No

2. SerloRenderer, type SerloRendererProps

  • Why Exported/How Used: SerloRenderer is a component provided by the @serlo/editor for rendering content in a non-editable format. This is particularly useful for displaying the content to users who are not currently editing or are not allowed to edit.
  • Long-Term Support: Will stay
  • Needs Change?: No

3. type BaseEditor

  • Why Exported/How Used: This type describes the editor render prop provided by the SerloEditor component.
  • Long-Term Support: Will stay unless a better solution is found
  • Needs Change?: Unclear

4. EditorPluginType

  • Why Exported/How Used: Can be used in the SerloEditor prop plugins to enable / disable plugins. Currently only used in serlo-editor-for-edusharing because we don't use the default plugins there.
  • Long-Term Support: Might stay. But should be used only in exceptional cases.
  • Needs Change?: Unclear

5. type EditorVariant

  • Why Exported/How Used: The variant of the Serlo editor. For example serlo-editor-for-edusharing or serlo.org. The editor adds this information to the StorageFormat that will be saved. Might become useful for example if we need to apply a migration only to one variant of the editor.
  • Long-Term Support: Unsure
  • Needs Change?: Unsure

6. defaultPlugins

  • Why Exported/How Used: List of plugins that are active per default. Can be used in the SerloEditor prop plugins to enable / disable plugins. Currently only used in serlo-editor-for-edusharing because we modify the default plugins there.
  • Long-Term Support: Unsure
  • Needs Change?: Unsure

7. type LearnerEventData

  • Why Exported/How Used: This is how the SerloRenderer provides the details of a learners interaction to handleLearnerEvent (see below).
  • Long-Term Support: Unsure
  • Needs Change?: Unsure

SerloEditor component props (SerloEditorProps)

  • children: When passed in a function as the children prop, the SerloEditor component provides an editor render prop as the argument to the children function. This editor object provides:

    • element - a React node for rendering the editor
    • i18n - for customizing translation strings
    • history - for persisting, undo, redo
    • selectRootDocument - a function for selecting the current state
  • plugins (optional): List of plugins that should be active. If undefined, the defaultPlugins will be used. Only use this if you need to filter out some plugins. Upon first render, the object will be frozen and you can't dynamically change the plugins anymore! Ensure to do any filtering before you render the Serlo Editor.

  • initialState (optional): Pass in an initialState to the SerloEditor component to prevent seeing an empty editor state. Here is the documentation for sample initial states of each plugin, in case you want to render the Editor displaying a particular plugin by default.

  • onChange (optional): To receive state changes of the editor and persist the content into your own infrastructure, use the onChange callback of the SerloEditor component. It's a function with the signature (state: StorageFormat) => void.

  • language (optional): The default language is de.

  • editorVariant: The variant (integration) of the Serlo editor. For example edusharing or serlo-org. The editor adds this information to the StorageFormat that will be saved. Might become useful for example if we need to apply a migration only to one variant of the editor.

  • _testingSecret (optional): Required to use Image plugin in testing. A key used by integrations for uploading files into the serlo-editor-testing bucket, while testing the Editor. To be deprecated once a long term solution is agreed on.

  • _ltik (optional): Required by the custom plugin edusharingAsset only used in serlo-editor-for-edusharing. To be removed once a better solution is found or the plugin is removed.

SerloRenderer component props (SerloRendererProps)

  • For language, state, _ltik and editorVariant please see props for SerloEditor above.

  • handleLearnerEvent (optional): Function that receives details about the learners interaction in the form of LearnerEventData. Provide if you want to connect the editor to you LRS (Learning Record Store) or similar. In our wiki you can find more details and a xAPI example.

pluginMenuEn / pluginMenuDe constant and Plugin enum

Exports two records with following structure which you can use to create your own plugin menu in either German or English. This is useful when you for example want to integrate the Serlo Editor as a block / part of another editor.

[key: Plugin]: {
  title: string
  description: string
  icon: string
  type: Plugin
  initialState: PluginState
}

You can iterate over this structure by using Object.values(plugins) to get an array, which you can use to sort, filter and modify to your liking. Alternatively you can access an entry as for example pluginMenuEn[Plugin.SingleChoiceExercise].

Releasing a new version to npm

Bump the version number in the package.json and the github workflow seen inside editor.yaml will take care of the publishing.

Linking for local development with integrations

In order to avoid publishing the editor to NPM or dealing with tarballs every time you need to test your changes in an integration locally, you can use yalc to link the editor package to your integration locally.

Prerequisites:

  • Yalc: yarn global add yalc

Initial steps:

  1. From this workspace -> run yarn yalc:publish
  2. From consumer repo -> run yalc add @serlo/editor

After making some changes in the editor:

  1. From this workspace -> run yarn yalc:publish (pushes dist, updates version and cache)

To remove the local link to Serlo Editor:

  1. From consumer repo -> run yalc remove @serlo/editor