I am using Monaco Editor v 0.10.1 in a webpage, and wonder if anybody knows if it is possible to add a set of Snippets that will pop up in Command Palette -> Insert Snippet like for the Visual Code editor.
I am using Monaco Editor v 0.10.1 in a webpage, and wonder if anybody knows if it is possible to add a set of Snippets that will pop up in Command Palette -> Insert Snippet like for the Visual Code editor.
Share Improve this question asked Jan 11, 2018 at 16:43 Jan RyghJan Rygh 611 silver badge3 bronze badges3 Answers
Reset to default 5monaco.languages.registerCompletionItemProvider('javascript', {
provideCompletionItems: () => {
return {
suggestions: [
{
label: 'Async Block',
kind: monaco.languages.CompletionItemKind.Snippet,
documentation: 'Add an async block',
insertText: [
'(async () => {',
'\t',
'})()'].join('\n')
}
]
};
}
});
Reference: https://microsoft.github.io/monaco-editor/playground.html#extending-language-services-pletion-provider-example
You can use the AddAction method to do this...
//Register a custom snippet
monaco.languages.registerCompletionItemProvider('javascript', {
provideCompletionItems: () => {
return [
{
label: 'for: Array',
kind: monaco.languages.CompletionItemKind.Snippet,
documentation: 'Iterate over an Array',
insertText: [
'for(let i=0; i < arr.length; i++){',
'\tlet elem = arr[i];',
'',
'}'].join('\n')
}
]
}
});
//Add custom action
this.editor = window.monaco.editor.create(this.$el, options);
window.activeEditor = this.editor
this.editor.addAction({
id: 'insert-text-at-cusor-mand',
label: 'Command Snippet',
keybindings: [monaco.KeyMod.CtrlCmd | monaco.KeyCode.F10],
contextMenuGroupId: 'snippets',
contextMenuOrder: 1.5,
run: function (ed) {
activeEditor.focus()
activeEditor.trigger('keyboard', 'type', {text: "for"});
}
});
No, not in the current version - hopefully there will e an updated version soon :) But you can however register your own snippet in code the will be available in autoplete / CTRL + SPACE and then later in the mand palette.