Open-source WYSIWYG .docx editor for React with canonical OOXML, tracked changes, and real-time collaboration. Agent-ready. Live demo | Documentation
npm install @eigenpal/docx-js-editorimport { useRef } from 'react';
import { DocxEditor, type DocxEditorRef } from '@eigenpal/docx-js-editor';
import '@eigenpal/docx-js-editor/styles.css';
function Editor({ file }: { file: ArrayBuffer }) {
const editorRef = useRef<DocxEditorRef>(null);
return <DocxEditor ref={editorRef} documentBuffer={file} mode="editing" onChange={() => {}} />;
}Next.js / SSR: Use dynamic import — the editor requires the DOM.
| Package | Description |
|---|---|
@eigenpal/docx-js-editor |
React UI — toolbar, paged editor, plugins. Install this. |
@eigenpal/docx-editor-vue |
Vue.js scaffold — contributions welcome |
import { DocxEditor, PluginHost, templatePlugin } from '@eigenpal/docx-js-editor';
<PluginHost plugins={[templatePlugin]}>
<DocxEditor documentBuffer={file} />
</PluginHost>;See the plugin documentation for the full plugin API.
bun install
bun run dev # localhost:5173
bun run build
bun run typecheckA live preview of main is auto-deployed at latest.docx-editor.dev — useful for trying out changes before they ship to npm.
Examples: Vite | Next.js | Remix | Astro | Vue
Documentation | Props & Ref Methods | Plugins | Architecture
| Locale | Language | Coverage |
|---|---|---|
en |
English | 100% |
de |
German | 100% |
pl |
Polish | 100% |
pt-BR |
Portuguese (Brazil) | 100% |
Help translate the editor into your language! See the full i18n contribution guide.
bun run i18n:new de # scaffold German locale
bun run i18n:status # check translation coverageTip
Questions or custom features? Email docx-editor@eigenpal.com.