@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
Keywords
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 theSerloEditor
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
propplugins
to enable / disable plugins. Currently only used inserlo-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
orserlo.org
. The editor adds this information to theStorageFormat
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
propplugins
to enable / disable plugins. Currently only used inserlo-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 tohandleLearnerEvent
(see below). - Long-Term Support: Unsure
- Needs Change?: Unsure
SerloEditor
component props (SerloEditorProps
)
children
: When passed in a function as thechildren
prop, theSerloEditor
component provides aneditor
render prop as the argument to thechildren
function. Thiseditor
object provides:element
- a React node for rendering the editori18n
- for customizing translation stringshistory
- for persisting, undo, redoselectRootDocument
- a function for selecting the current state
plugins
(optional): List of plugins that should be active. If undefined, thedefaultPlugins
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 aninitialState
to theSerloEditor
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 theonChange
callback of theSerloEditor
component. It's a function with the signature(state: StorageFormat) => void
.language
(optional): The default language isde
.editorVariant
: The variant (integration) of the Serlo editor. For exampleedusharing
orserlo-org
. The editor adds this information to theStorageFormat
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 pluginedusharingAsset
only used inserlo-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
andeditorVariant
please see props forSerloEditor
above.handleLearnerEvent
(optional): Function that receives details about the learners interaction in the form ofLearnerEventData
. 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:
- From this workspace -> run
yarn yalc:publish
- From consumer repo -> run
yalc add @serlo/editor
After making some changes in the editor:
- From this workspace -> run
yarn yalc:publish
(pushes dist, updates version and cache)
To remove the local link to Serlo Editor:
- From consumer repo -> run
yalc remove @serlo/editor