Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
editorjs-undo
Advanced tools
Undo/Redo feature for Editor.js.
This new version introduces breaking changes. Remember that it is still in beta version.
Please, report bugs or behavior issues :).
Get the package
$ npm i --save-dev editorjs-undo
To install the latest v1 stable version
Get the package
$ npm i --save-dev editorjs-undo@1.0.1
Include module in your application
import Undo from 'editorjs-undo';
const editor = new EditorJS({
onReady: () => {
new Undo({ editor });
},
});
On the editor, use Ctrl + Z or ⌘ + Z to undo, or use Ctrl + Y or ⌘ + Y to redo.
If you are using react-editor-js, you could create a function to handle the onReady property, the function will store the undo instance and the respective configuration or initialize method if you want to use them (they will be explained below). Then, you must call the function in onReady in the editorJS instance.
const handleReady = (editor) => {
new Undo({ editor });
};
class ReactEditor extends Component {
render() {
return (
<EditorJs
onReady = { handleReady }
tools = { ... }
/>
)
}
}
Note: If you are already using editorjs-drag-drop your handleReady function must have the editorjs-drag-drop instance.
const handleReady = (editor) => {
new Undo({ editor });
new DragDrop(editor);
};
Note: If you have loaded EditorJS with any initial data (such as some saved content), you must pass in an initialData
object. If you don't, the default initial undo state lead to an empty editor.
You may use the initialize
method inside the editor's onReady
callback.
const editor = new EditorJS({
onReady: () => {
const undo = new Undo({ editor });
undo.initialize(initialData);
},
});
Note: If you do not add any shortcut, the default shortcuts will be set up.
If you want to add custom shortcuts, pass a config object with a shortcut key in the undo instance, the shortcuts must be called undo
and redo
.
const config = {
shortcuts: {
undo: 'CMD+X',
redo: 'CMD+ALT+C'
}
}
const editor = new EditorJS({
onReady: () => {
const undo = new Undo({ editor, config });
},
});
You can set each shortcut with two or three keys, the available special keys are: CMD, ALT, SHIFT. CMD will be set up automatically as Ctrl or ⌘ depending on your OS.
Internally, editorjs-undo uses an Observer instance that watches for changes in the text being entered. By default, it waits for a pause of 200ms in text entry before saving a change. If you want to have editorjs-undo save changes more or less often, pass a config object with a debounceTimer key in the undo instance and provide a different value in milliseconds.
const config = {
debounceTimer: 100
};
const editor = new EditorJS({
onReady: () => {
const undo = new Undo({ editor, config });
},
});
Lowering the debounceTimer value below 200ms will make editorjs-undo save changes more often. Raising the debounceTimer value above 200ms will make editorjs-undo save changes less often.
Setting the debounceTimer value to 0 makes editorjs-undo save every character entered as an individual change, which makes undo and redo operations only remove/replace one character at a time.
Field | Type | Description |
---|---|---|
editor | EditorJS | Required. The EditorJS instance. |
maxLength | Number | Max amount of changes recorded by the history stack. |
onUpdate() | function | Callback called when the user performs an undo or redo action. |
config | object | Set up the configuration to editorjs-undo like the shortcuts |
Development mode
$ yarn build:dev
Production release
$ yarn build
dist/bundle.js
Run tests
$ yarn test
We welcome everyone to contribute. Make sure you have read the CODE_OF_CONDUCT before.
For information on how to contribute, please refer to our CONTRIBUTING guide.
Features and bug fixes are listed in the CHANGELOG file.
This library is licensed under an MIT license. See LICENSE for details.
Made with 💙 by kommitters Open Source
2.0.3 (08.06.2022)
FAQs
Undo tool for Editor.js
The npm package editorjs-undo receives a total of 13,707 weekly downloads. As such, editorjs-undo popularity was classified as popular.
We found that editorjs-undo demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.