umbraco-monaco-markdown-editor-action

Umbraco Monaco Markdown Editor Action

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "umbraco-monaco-markdown-editor-action" with this command: npx skills add umbraco/umbraco-cms-backoffice-skills/umbraco-umbraco-cms-backoffice-skills-umbraco-monaco-markdown-editor-action

Umbraco Monaco Markdown Editor Action

What is it?

Monaco Markdown Editor Actions add custom toolbar buttons and keyboard shortcuts to the Markdown editor in Umbraco. They allow you to extend the editing experience with custom functionality like inserting links, images, or custom markdown syntax. Actions appear in the editor toolbar and can respond to keyboard shortcuts.

Documentation

Always fetch the latest docs before implementing:

Related Foundation Skills

Modals: When opening modal dialogs from actions

  • Reference skill: umbraco-modals

Localization: When providing localized labels

  • Reference skill: umbraco-localization

Workflow

  • Fetch docs - Use WebFetch on the URLs above

  • Ask questions - What functionality? What keyboard shortcut? What icon?

  • Generate files - Create manifest + action class based on latest docs

  • Explain - Show what was created and how to test

Minimal Examples

Manifest (manifests.ts)

export const manifests: Array<UmbExtensionManifest> = [ { type: 'monacoMarkdownEditorAction', alias: 'My.MonacoMarkdownEditorAction.Custom', name: 'Custom Monaco Markdown Editor Action', api: () => import('./my-markdown-action.js'), meta: { label: 'Insert Custom', icon: 'icon-favorite', }, }, ];

Action Implementation (my-markdown-action.ts)

import { monaco } from '@umbraco-cms/backoffice/external/monaco-editor'; import { UmbControllerBase } from '@umbraco-cms/backoffice/class-api'; import type { UmbControllerHost } from '@umbraco-cms/backoffice/controller-api'; import type { UUIModalSidebarSize } from '@umbraco-cms/backoffice/external/uui';

export class MyMarkdownAction extends UmbControllerBase { constructor(host: UmbControllerHost) { super(host); }

getUnique() { return 'My.MonacoMarkdownEditorAction.Custom'; }

getLabel() { return 'Insert Custom'; }

getKeybindings() { // Ctrl/Cmd + Shift + C return [monaco.KeyMod.CtrlCmd | monaco.KeyMod.Shift | monaco.KeyCode.KeyC]; }

async execute({ editor, overlaySize }: { editor: any; overlaySize: UUIModalSidebarSize }) { if (!editor) throw new Error('Editor not found');

const selection = editor.getSelections()[0];
if (!selection) return;

const selectedValue = editor.getValueInRange(selection);

// Insert custom markdown
editor.monacoEditor?.executeEdits('', [
  { range: selection, text: `**${selectedValue || 'custom'}**` },
]);

editor.monacoEditor?.focus();

} }

export { MyMarkdownAction as api };

Action with Modal

import { monaco } from '@umbraco-cms/backoffice/external/monaco-editor'; import { UmbControllerBase } from '@umbraco-cms/backoffice/class-api'; import { UMB_MODAL_MANAGER_CONTEXT } from '@umbraco-cms/backoffice/modal';

export class MyModalMarkdownAction extends UmbControllerBase { getUnique() { return 'My.MonacoMarkdownEditorAction.Modal'; }

getLabel() { return 'Insert with Modal'; }

getKeybindings() { return [monaco.KeyMod.CtrlCmd | monaco.KeyCode.KeyM]; }

async execute({ editor, overlaySize }) { const modalManager = await this.getContext(UMB_MODAL_MANAGER_CONTEXT); if (!modalManager) throw new Error('Modal manager not found');

const selection = editor?.getSelections()[0];
if (!selection) return;

// Open a modal and use the result
const modalContext = modalManager.open(this, MY_CUSTOM_MODAL, {
  modal: { size: overlaySize },
});

modalContext?.onSubmit().then((value) => {
  if (!value) return;
  editor.monacoEditor?.executeEdits('', [
    { range: selection, text: value.text },
  ]);
});

} }

export { MyModalMarkdownAction as api };

Interface Reference

interface ManifestMonacoMarkdownEditorAction extends ManifestApi<any> { type: 'monacoMarkdownEditorAction'; meta?: MetaMonacoMarkdownEditorAction; }

interface MetaMonacoMarkdownEditorAction { icon?: string | null; label?: string | null; // Can use localization key like '#buttons_linkInsert' }

Common Key Bindings

// Single key monaco.KeyCode.Enter

// Ctrl/Cmd combinations monaco.KeyMod.CtrlCmd | monaco.KeyCode.KeyK // Ctrl+K or Cmd+K monaco.KeyMod.CtrlCmd | monaco.KeyMod.Shift | monaco.KeyCode.KeyC // Ctrl+Shift+C monaco.KeyMod.Alt | monaco.KeyCode.KeyI // Alt+I

That's it! Always fetch fresh docs, keep examples minimal, generate complete working code.

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

General

umbraco-backoffice

No summary provided by upstream source.

Repository SourceNeeds Review
General

umbraco-dashboard

No summary provided by upstream source.

Repository SourceNeeds Review
General

umbraco-quickstart

No summary provided by upstream source.

Repository SourceNeeds Review
General

umbraco-extension-template

No summary provided by upstream source.

Repository SourceNeeds Review