
Product
Socket Firewall Now Blocks Malicious VS Code and Open VSX Extensions
Socket Firewall blocks malicious VS Code and Open VSX extensions before install, protecting developers from compromised editor marketplaces.
@romeovs/react-ace
Advanced tools
A react component for Ace / Brace
npm install react-ace
import React from 'react';
import { render } from 'react-dom';
import brace from 'brace';
import AceEditor from 'react-ace';
import 'brace/mode/java';
import 'brace/theme/github';
function onChange(newValue) {
console.log('change',newValue);
}
// Render editor
render(
<AceEditor
mode="java"
theme="github"
onChange={onChange}
name="UNIQUE_ID_OF_DIV"
editorProps={{$blockScrolling: true}}
/>,
document.getElementById('example')
);
Looking for a way to set it up using webpack? Checkout example directory for a working example using webpack.
| Prop | Description |
|---|---|
| name | Unique Id to be used for the editor |
| mode | Language for parsing and code highlighting |
| theme | theme to use |
| height | CSS value for height |
| width | CSS value for width |
| className | custom className |
| fontSize | pixel value for font-size |
| showGutter | boolean |
| showPrintMargin | boolean |
| highlightActiveLine | boolean |
| readOnly | boolean |
| minLines | Minimum number of lines to be displayed |
| maxLines | Maximum number of lines to be displayed |
| enableBasicAutocompletion | Enable basic autocompletion |
| enableSnippets | Enable snippets |
| enableLiveAutocompletion | Enable live autocompletion |
| tabSize | tabSize number |
| value | String value you want to populate in the code highlighter |
| onLoad | Function onLoad |
| onBeforeLoad | function that trigger before editor setup |
| onChange | function that occurs on document change it has 1 argument value. see the example above |
| onCopy | function that trigger by editor copy event, and pass text as argument |
| onPaste | function that trigger by editor paste event, and pass text as argument |
| onFocus | function that trigger by editor focus event |
| onBlur | function that trigger by editor blur event |
| editorProps | Object of properties to apply directly to the Ace editor instance |
| setOptions | Object of options to apply directly to the Ace editor instance |
| keyboardHandler | String corresponding to the keybinding mode to set (such as vim) |
| commands | Array of new commands to add to the editor |
| annotations | Array of annotations to show in the editor i.e. [{ row: 0, column: 2, type: 'error', text: 'Some error.'}], displayed in the gutter |
| markers | Array of markers to show in the editor, i.e. [{ startRow: 0, startCol: 2, endRow: 1, endCol: 20, className: 'error-marker', type: 'background' }] |
All modes, themes, and keyboard handlers should be required through brace directly. Browserify will grab these modes / themes / keyboard handlers through brace and will be available at run time. See the example above. This prevents bloating the compiled javascript with extra modes and themes for your application.
FAQs
A react component for Ace Editor
We found that @romeovs/react-ace demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer 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.

Product
Socket Firewall blocks malicious VS Code and Open VSX extensions before install, protecting developers from compromised editor marketplaces.

Research
More than 140 Mastra npm packages were compromised in a supply chain attack that used a typosquatted dependency to deliver a cross-platform infostealer during installation.

Research
/Security News
A new npm package tests AI malware scanners with prompt injection, safety-triggering comments, context flooding, and obfuscated JavaScript.