Codejar
An embeddable code editor for the browser 🍯
Install / Use
/learn @antonmedv/CodejarREADME
Features
- Lightweight (2.45 kB only)
- No dependencies
- Preserves indentation on a new line
- Adds closing brackets, quotes
- Indents line with the Tab key
- Supports undo/redo
Getting Started
Install CodeJar 🍯 via npm:
npm i codejar
Create an element and init the CodeJar 🍯:
<div class="editor"></div>
<script>
let jar = CodeJar(document.querySelector('.editor'), highlight)
</script>
Second argument to CodeJar is a highlighting function (like Prism.js, highlight.js):
const highlight = (editor: HTMLElement) => {
const code = editor.textContent
code = code.replace('foo', '<span style="color: red">foo</span>')
editor.innerHTML = code
}
const jar = CodeJar(editor, highlight)
Third argument to CodeJar is options:
tab: stringreplaces "tabs" with given string. Default:\t.- Note: use css rule
tab-sizeto customize size.
- Note: use css rule
indentOn: RegExpallows auto indent rule to be customized. Default/[({\[]$/.moveToNewLine: RegExpchecks in extra newline character need to be added. Default/^[)}\]]/.spellcheck: booleanenables spellchecking on the editor. Defaultfalse.catchTab: booleancatches Tab keypress events and replaces it withtabstring. Default:true.preserveIdent: booleankeeps indent levels on new line. Defaulttrue.addClosing: booleanautomatically adds closing brackets, quotes. Defaulttrue.historyrecords history. Defaulttrue.windowwindow object. Default:window.autocloseobjectopen stringcharacters that triggers the autoclose functionclose stringcharacters that correspond to the opening ones and close the object.
const options = {
tab: ' '.repeat(4), // default is '\t'
indentOn: /[(\[]$/, // default is /{$/
autoclose: {
open: `([{*`, // default is `([{'"`
close: `)]}*` // default is `)]}'"`
}
}
const jar = CodeJar(editor, highlight, options)
API
updateCode(string)
Updates the code.
jar.updateCode(`let foo = bar`)
updateOptions(Partial<Options>)
Updates the options.
jar.updateOptions({tab: '\t'})
onUpdate((code: string) => void)
Calls callback on code updates.
jar.onUpdate(code => {
console.log(code)
})
toString(): string
Return current code.
let code = jar.toString()
save(): string
Saves current cursor position.
let pos = jar.save()
restore(pos: Position)
Restore cursor position.
jar.restore(pos)
recordHistory()
Saves current editor state to history.
destroy()
Removes event listeners from editor.
Related
- react-codejar - a React wrapper for CodeJar.
- ngx-codejar - an Angular wrapper for CodeJar.
- codejar-linenumbers - an JS library for line numbers.
License
Related Skills
node-connect
344.4kDiagnose OpenClaw node connection and pairing failures for Android, iOS, and macOS companion apps
frontend-design
99.2kCreate distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
openai-whisper-api
344.4kTranscribe audio via OpenAI Audio Transcriptions API (Whisper).
qqbot-media
344.4kQQBot 富媒体收发能力。使用 <qqmedia> 标签,系统根据文件扩展名自动识别类型(图片/语音/视频/文件)。
