sample.js 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. function createDependencyProposals() {
  2. // returning a static list of proposals, not even looking at the prefix (filtering is done by the Monaco editor),
  3. // here you could do a server side lookup
  4. return [
  5. {
  6. label: '"lodash"',
  7. kind: monaco.languages.CompletionItemKind.Function,
  8. documentation: "The Lodash library exported as Node.js modules.",
  9. insertText: '"lodash": "*"'
  10. },
  11. {
  12. label: '"express"',
  13. kind: monaco.languages.CompletionItemKind.Function,
  14. documentation: "Fast, unopinionated, minimalist web framework",
  15. insertText: '"express": "*"'
  16. },
  17. {
  18. label: '"mkdirp"',
  19. kind: monaco.languages.CompletionItemKind.Function,
  20. documentation: "Recursively mkdir, like <code>mkdir -p</code>",
  21. insertText: '"mkdirp": "*"'
  22. }
  23. ];
  24. }
  25. monaco.languages.registerCompletionItemProvider('json', {
  26. provideCompletionItems: function(model, position) {
  27. // find out if we are completing a property in the 'dependencies' object.
  28. var textUntilPosition = model.getValueInRange({startLineNumber: 1, startColumn: 1, endLineNumber: position.lineNumber, endColumn: position.column});
  29. var match = textUntilPosition.match(/"dependencies"\s*:\s*{\s*("[^"]*"\s*:\s*"[^"]*"\s*,\s*)*("[^"]*)?$/);
  30. if (match) {
  31. return createDependencyProposals();
  32. }
  33. return [];
  34. }
  35. });
  36. monaco.editor.create(document.getElementById("container"), {
  37. value: "{\n\t\"dependencies\": {\n\t\t\n\t}\n}\n",
  38. language: "json"
  39. });