Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/antonmedv/codejar
An embeddable code editor for the browser ๐ฏ
https://github.com/antonmedv/codejar
code-editor
Last synced: 4 days ago
JSON representation
An embeddable code editor for the browser ๐ฏ
- Host: GitHub
- URL: https://github.com/antonmedv/codejar
- Owner: antonmedv
- License: mit
- Created: 2020-03-31T13:01:35.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2024-11-11T20:44:07.000Z (3 months ago)
- Last Synced: 2025-01-14T11:12:01.305Z (11 days ago)
- Topics: code-editor
- Language: TypeScript
- Homepage: https://medv.io/codejar/
- Size: 83 KB
- Stars: 1,826
- Watchers: 20
- Forks: 119
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome - antonmedv/codejar - An embeddable code editor for the browser ๐ฏ (TypeScript)
- my-awesome-list - codejar
- best-of-react - GitHub - 11% open ยท โฑ๏ธ 08.01.2024): (Editor Components)
README
CodeJar โ an embeddable code editor for the browser
[![npm](https://img.shields.io/npm/v/codejar?color=brightgreen)](https://www.npmjs.com/package/codejar)
[![npm bundle size](https://img.shields.io/bundlephobia/minzip/codejar?label=size)](https://bundlephobia.com/result?p=codejar)## 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:
```bash
npm i codejar
```Create an element and init the CodeJar ๐ฏ:
```html
let jar = CodeJar(document.querySelector('.editor'), highlight)
```
Second argument to `CodeJar` is a highlighting function (like Prism.js, highlight.js):
```ts
const highlight = (editor: HTMLElement) => {
const code = editor.textContent
code = code.replace('foo', 'foo')
editor.innerHTML = code
}const jar = CodeJar(editor, highlight)
```Third argument to `CodeJar` is options:
- `tab: string` replaces "tabs" with given string. Default: `\t`.
- Note: use css rule `tab-size` to customize size.
- `indentOn: RegExp` allows auto indent rule to be customized. Default `/[({\[]$/`.
- `moveToNewLine: RegExp` checks in extra newline character need to be added. Default `/^[)}\]]/`.
- `spellcheck: boolean` enables spellchecking on the editor. Default `false`.
- `catchTab: boolean` catches Tab keypress events and replaces it with `tab` string. Default: `true`.
- `preserveIdent: boolean` keeps indent levels on new line. Default `true`.
- `addClosing: boolean` automatically adds closing brackets, quotes. Default `true`.
- `history` records history. Default `true`.
- `window` window object. Default: `window`.
- `autoclose` object
- `open string` characters that triggers the autoclose function
- `close string` characters that correspond to the opening ones and close the object.```js
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.
```js
jar.updateCode(`let foo = bar`)
```#### `updateOptions(Partial)`
Updates the options.
```js
jar.updateOptions({tab: '\t'})
```#### `onUpdate((code: string) => void)`
Calls callback on code updates.
```js
jar.onUpdate(code => {
console.log(code)
})
```#### `toString(): string`
Return current code.
```js
let code = jar.toString()
```#### `save(): string`
Saves current cursor position.
```js
let pos = jar.save()
```#### `restore(pos: Position)`
Restore cursor position.
```js
jar.restore(pos)
```#### `recordHistory()`
Saves current editor state to history.
#### `destroy()`
Removes event listeners from editor.
## Related
* [react-codejar](https://github.com/guilhermelimak/react-codejar) - a React wrapper for CodeJar.
* [ngx-codejar](https://github.com/julianpoemp/ngx-codejar) - an Angular wrapper for CodeJar.
* [codejar-linenumbers](https://github.com/julianpoemp/codejar-linenumbers) - an JS library for line numbers.## License
[MIT](LICENSE)