Edit and Export as mediawiki in Etherpad.
- Etherpad plugin framework (hooks declared in
ep.json) - EJS templates rendered server-side via
eejsBlock_*hooks ep_plugin_helpersfor shared boilerplate
ep_mediawiki/
├── AGENTS.md
├── CONTRIBUTING.md
├── LICENSE.md
├── ep.json
├── export.js
├── exportMediaWiki.js
├── express.js
├── index.js
├── package.json
├── static/
│ ├── css/
│ ├── js/
│ ├── tests/
├── templates/
│ ├── exportcolumn.html
│ ├── scripts.html
padToggle(client sub-path) fromep_plugin_helperspadToggle(server) fromep_plugin_helpers
To be audited in the helpers-adoption sweep (Phase 4).
ep_mediawiki runs inside Etherpad's test harness. From an etherpad checkout that has installed this plugin via pnpm run plugins i --path ../ep_mediawiki:
# Backend (Mocha) — harness boots its own server
pnpm --filter ep_etherpad-lite run test
# Playwright — needs `pnpm run dev` in a second terminal
pnpm --filter ep_etherpad-lite run test-ui- PRs target
main. Linear commits, no merge commits. - Every bug fix includes a regression test in the same commit.
- All user-facing strings in
locales/. No hardcoded English in templates. - No hardcoded
aria-labelon icon-only controls — etherpad's html10n auto-populatesaria-labelfrom the localized string when (a) the element has adata-l10n-idand (b) no author-suppliedaria-labelis present. Adding a hardcoded Englisharia-labelblocks that and leaves it untranslated. (Seeetherpad-lite/src/static/js/vendors/html10n.ts:665-678.) - No nested interactive elements (no
<button>inside<a>). - LLM/Agent contributions are explicitly welcomed by maintainers.
- Server:
getLineHTMLForExport,expressCreateServer,loadSettings,clientVars,eejsBlock_exportColumn,eejsBlock_scripts,eejsBlock_mySettings,eejsBlock_padSettings - Client:
aceEditorCSS,postAceInit,handleClientMessage_CLIENT_MESSAGE
When adding a hook, register it in both ep.json and the matching exports.<hook> = ... in the JS file.