Youtube URL unfurl

pull/719/head
Zef Hemel 2024-02-24 13:16:04 +01:00
parent d299b1f13f
commit cafe39135e
5 changed files with 49 additions and 8 deletions

View File

@ -178,19 +178,31 @@ functions:
key: "Ctrl-Shift-u" key: "Ctrl-Shift-u"
mac: "Cmd-Shift-u" mac: "Cmd-Shift-u"
requireMode: rw requireMode: rw
contexts:
- NakedURL
# Title-based link unfurl # Title-based link unfurl
titleUnfurlOptions: titleUnfurlOptions:
path: ./link.ts:titleUnfurlOptions path: ./link.ts:titleUnfurlOptions
events: events:
- unfurl:options - unfurl:options
titleUnfurl: titleUnfurl:
path: ./link.ts:titleUnfurl path: ./link.ts:titleUnfurl
events: events:
- unfurl:title-unfurl - unfurl:title-unfurl
# Title-based link unfurl
youtubeUnfurlOptions:
path: ./link.ts:youtubeUnfurlOptions
events:
- unfurl:options
youtubeUnfurl:
path: ./link.ts:youtubeUnfurl
events:
- unfurl:youtube-unfurl
embedWidget: embedWidget:
path: ./embed.ts:embedWidget path: ./embed.ts:embedWidget
codeWidget: embed codeWidget: embed

View File

@ -7,7 +7,7 @@ type EmbedConfig = {
width?: number; width?: number;
}; };
function extractYoutubeVideoId(url: string) { export function extractYoutubeVideoId(url: string) {
let match = url.match(/youtube\.com\/watch\?v=([^&]+)/); let match = url.match(/youtube\.com\/watch\?v=([^&]+)/);
if (match) { if (match) {
return match[1]; return match[1];

View File

@ -1,5 +1,6 @@
import { nodeAtPos } from "$lib/tree.ts"; import { nodeAtPos } from "$lib/tree.ts";
import { editor, events, markdown } from "$sb/syscalls.ts"; import { editor, events, markdown } from "$sb/syscalls.ts";
import { extractYoutubeVideoId } from "./embed.ts";
type UnfurlOption = { type UnfurlOption = {
id: string; id: string;
@ -8,7 +9,15 @@ type UnfurlOption = {
export async function unfurlCommand() { export async function unfurlCommand() {
const mdTree = await markdown.parseMarkdown(await editor.getText()); const mdTree = await markdown.parseMarkdown(await editor.getText());
const nakedUrlNode = nodeAtPos(mdTree, await editor.getCursor()); const cursorPos = await editor.getCursor();
let nakedUrlNode = nodeAtPos(mdTree, cursorPos);
if (nakedUrlNode?.type !== "NakedURL") {
nakedUrlNode = nodeAtPos(mdTree, cursorPos - 1);
}
if (nakedUrlNode?.type !== "NakedURL") {
await editor.flashNotification("No URL found under cursor", "error");
return;
}
const url = nakedUrlNode!.children![0].text!; const url = nakedUrlNode!.children![0].text!;
console.log("Got URL to unfurl", url); console.log("Got URL to unfurl", url);
const optionResponses = await events.dispatchEvent("unfurl:options", url); const optionResponses = await events.dispatchEvent("unfurl:options", url);
@ -67,3 +76,20 @@ export async function titleUnfurl(url: string): Promise<string> {
throw new Error("No title found"); throw new Error("No title found");
} }
} }
export function youtubeUnfurlOptions(url: string): UnfurlOption[] {
if (extractYoutubeVideoId(url)) {
return [
{
id: "youtube-unfurl",
name: "Embed video",
},
];
} else {
return [];
}
}
export function youtubeUnfurl(url: string): string {
return "```embed\nurl: " + url + "\n```";
}

View File

@ -25,6 +25,7 @@ _These features are not yet properly released, you need to use [the edge builds]
* Changed the signature of `silverbullet.registerFunction` to make the first argument an object, see [[Space Script#Custom functions]]. Old string-based scripts still work, for backwards compatibility. * Changed the signature of `silverbullet.registerFunction` to make the first argument an object, see [[Space Script#Custom functions]]. Old string-based scripts still work, for backwards compatibility.
* The [[Functions#replace(str, match, replacement)]] function now supports multiple replacements * The [[Functions#replace(str, match, replacement)]] function now supports multiple replacements
* You can now use backticks (`) around identifiers in [[Expression Language]], to e.g. use names with spaces or other weird characters as attribute names. * You can now use backticks (`) around identifiers in [[Expression Language]], to e.g. use names with spaces or other weird characters as attribute names.
* [[Link Unfurl]] now supports unfurling youtube videos
* Fixed edit button on code widgets after they have shifted * Fixed edit button on code widgets after they have shifted
* Fixed page completion in template blocks * Fixed page completion in template blocks
* Giant code reorganization (hopefully resulting in 0 regressions) * Giant code reorganization (hopefully resulting in 0 regressions)

View File

@ -1,5 +1,7 @@
SilverBullet has infrastructure to “unfurl” — that is: replace with something nice — various types of URLs. Unfurling can be triggered by putting your cursor on any “naked” URL, and running the {[Link: Unfurl]} command. SilverBullet has infrastructure to “unfurl” — that is: to replace links with something nicer. Unfurling can be triggered by putting your cursor on any “naked” URL (such as https://silverbullet.md), and running the {[Link: Unfurl]} command.
Plugs can provide custom unfurls for specific URL patterns. For instance the [[Plugs/Twitter]] plug provides the ability to unfurl tweets, and pull in their content. Plugs can provide custom unfurls for specific URL patterns.
[[Plugs/Editor]] provides a generic URL unfurl, adding a title for a url. Two supported out of the box are:
* A generic URL unfurl, adding a title for a url so `https://silverbullet.md` becomes `[SilverBullet](https://silverbullet.md)`.
* A youtube URL unfurl, replacing a Youtube link with an [[Live Embeds]] of that video.