preact
? webpack
? create-react-app
?Check out the example applications
ReactAce
has an editor property, which is the wrapped editor. You can use refs to get to the component, and then you should be able to use the editor on the component to run the function you need:
const reactAceComponent = this.refs.reactAceComponent;
const editor = reactAceComponent.editor;
editor.find(searchRegex, {
backwards: false,
wrap: true,
caseSensitive: false,
wholeWord: false,
regExp: true
});
Similarly, if you want to redo or undo, you can reference the editor from the refs
<button onClick={()=> {this.refs.editor.editor.undo()}}>Undo</button>
<button onClick={()=> {this.refs.editor.editor.redo()}}>Redo</button>
<ReactAce
editorProps={{
$blockScrolling: Infinity
}}
/>
You can import the snippets and mode directly through ace-builds
along with the language_tools. Here is an example below
import React from "react";
import { render } from "react-dom";
import AceEditor from "react-ace";
import "ace-builds/src-min-noconflict/ext-language_tools";
import "ace-builds/src-noconflict/mode-python";
import "ace-builds/src-noconflict/snippets/python";
import "ace-builds/src-noconflict/theme-github";
function onChange(newValue) {
console.log("change", newValue);
}
// Render editor
render(
<AceEditor
mode="python"
theme="github"
onChange={onChange}
name="UNIQUE_ID_OF_DIV"
editorProps={{ $blockScrolling: true }}
enableBasicAutocompletion={true}
enableLiveAutocompletion={true}
enableSnippets={true}
/>,
document.getElementById("example")
);
onSelectionChange
?How you extract the text from the editor is based on how to call methods on the editor.
Your onSelectionChange
should look like this:
onSelectionChange(selection) {
const content = this.refs.aceEditor.editor.session.getTextRange(selection.getRange());
// use content
}
const selectedText = this.refs.aceEditor.editor.getSelectedText();
// selectedText contains the selected text.
}
const markers = [
{
startRow: 3,
type: "text",
className: "test-marker"
}
];
const wrapper = <AceEditor markers={markers} />;
const annotations = [
{
row: 3, // must be 0 based
column: 4, // must be 0 based
text: "error.message", // text to show in tooltip
type: "error"
}
];
const editor = <AceEditor annotations={annotations} />;
render() {
return <div>
<AceEditor
ref="aceEditor"
mode="sql" // Default value since this props must be set.
theme="chrome" // Default value since this props must be set.
commands={[{ // commands is array of key bindings.
name: 'commandName', //name for the key binding.
bindKey: {win: 'Ctrl-Alt-h', mac: 'Command-Alt-h'}, //key combination used for the command.
exec: () => { console.log('key-binding used')} //function to execute when keys are pressed.
}]}
/>
</div>;
}
Same syntax as above, where exec
is given the name of the command to rebind.
render() {
return <div>
<AceEditor
ref="aceEditor"
mode="sql" // Default value since this props must be set.
theme="chrome" // Default value since this props must be set.
commands={[{ // commands is array of key bindings.
name: 'removeline', //name for the key binding.
bindKey: {win: 'Ctrl-X', mac: 'Command-X'}, //key combination used for the command.
exec: 'removeline' // name of the command to rebind
}]}
/>
</div>;
}
Add the following line
import 'ace-builds/src-min-noconflict/ext-searchbox';
before introducing the component and it will add the search box.
componentDidMount
function and call session.setMode
with an instance of my custom mode.My custom mode is:
import "ace-builds/src-noconflict/mode-java";
export class CustomHighlightRules extends window.ace.acequire(
"ace/mode/text_highlight_rules"
).TextHighlightRules {
constructor() {
super();
this.$rules = {
start: [
{
token: "comment",
regex: "#.*$"
},
{
token: "string",
regex: '".*?"'
}
]
};
}
}
export default class CustomSqlMode extends window.ace.acequire("ace/mode/java")
.Mode {
constructor() {
super();
this.HighlightRules = CustomHighlightRules;
}
}
And my react-ace code looks like:
import React, { Component } from "react";
import AceEditor from "react-ace";
import CustomSqlMode from "./CustomSqlMode.js";
import "ace-builds/src-noconflict/theme-github";
class App extends Component {
componentDidMount() {
const customMode = new CustomSqlMode();
this.refs.aceEditor.editor.getSession().setMode(customMode);
}
render() {
return (
<div className="App">
<AceEditor
ref="aceEditor"
mode="text"
theme="github"
name="UNIQUE_ID_OF_DIV"
editorProps={{ $blockScrolling: true }}
/>
</div>
);
}
}
export default App;