Advanced script actions

In addition to the basic script actions, you can also use more advanced script actions to interact with the user, ask questions, or execute scripts in bulk.

Asking questions

In case you need more information from a user to execute a script, you can ask questions using the askQuestions method from the ContentScript or MediaScript class.

You could for instance use this functionality to ask the user where they want to share an article, what the width and height of an image should be, or any other question you want to ask. Here is an example of how you can ask a question:

Ask questions
import { ContentScript } from "@frontmatter/extensibility";

(() => {
  const contentScriptArgs = ContentScript.getArguments();
  if (!contentScriptArgs) {
    contentScriptArgs.done(`No arguments found`);
    return;
  }

  // Retrieve the answers from the arguments
  const { answers } = contentScriptArgs;
  if (!answers) {
    // No answers found, ask the user
    ContentScript.askQuestions([{
      name: "platform",
      message: "Where do you want to share the article?",
      options: ["Twitter", "LinkedIn"]
    }]);
    // No further script execution is needed, the user will be prompted with the question
    return;
  }

  // Once the user answered the question, the script will be executed again
  // with the answers provided by the user
  ContentScript.done(`You selected ${answers.platform}`);
})();

When you run the script, the user will be prompted with the question "Where do you want to share the article?" and can select either "Twitter" or "LinkedIn".

Ask a question via the extensibility library

Prompting GitHub Copilot

If you are using GitHub Copilot, you can also prompt Copilot with your custom scripts. For example, you could use it to generate a social message which you want to share on X, or Bluesky.

Prompting GitHub Copilot
import { ContentScript } from "@frontmatter/extensibility";

(() => {
  const contentScriptArgs = ContentScript.getArguments();
  if (contentScriptArgs) {
    const {
      frontMatter: { title, description, slug },
      promptResponse
  } = contentScriptArgs;

  if (!promptResponse) {
    ContentScript.promptCopilot(`Create me a social message for sharing this article on Bluesky.
  To generate the post, please use the following information:

  Title: """${title}"""
  Description: """${description}"""

  The output should be plain text and should not include any markdown or HTML tags.
  You are free to add hashtags.

  IMPORTANT: Please make sure to keep the post under 265 characters.`);
    return;
  }

  const shareUrl = `https://bsky.app/intent/compose?text=${encodeURIComponent(promptResponse)}%20${encodeURIComponent(url)}`;
  ContentScript.open(shareUrl);
})();

Bulk execution

If you want, you can run a script for multiple content files at once. This is useful when you want to generate a social image for all your markdown files or perform any other bulk operation.

To enable bulk script execution, you need to configure the frontMatter.custom.scripts setting for your project as follows:

Bulk script configuration
{
  "frontMatter.custom.scripts": [
    {
      "title": "Generate social image",
      "script": "./scripts/social-img.js",
      "command": "~/.nvm/versions/node/v16.13.0/bin/node",
      "bulk": true,
      "output": "editor"
    }
  ]
}
Info

Since the introduction of the actions bar, you can now also select all items in the current view and run content or media scripts for all selected items.

Feedback/comments

Last updated on

Did you spot an issue in our documentation, or want to contribute? Edit this page on Github!

Ready to get started?

Special thanks to our backers & sponsors

run.events - Event Management PlatformNetlifyBEJS CommunityStruyf Consulting
Contributors
Dennis ZomaPatrick Kollitschmayumihara