2023-08-28 23:12:15 +08:00
|
|
|
import { YAML } from "$sb/syscalls.ts";
|
2024-02-09 04:00:45 +08:00
|
|
|
import type { WidgetContent } from "$type/types.ts";
|
2023-01-21 20:37:55 +08:00
|
|
|
|
|
|
|
type EmbedConfig = {
|
|
|
|
url: string;
|
|
|
|
height?: number;
|
|
|
|
width?: number;
|
|
|
|
};
|
|
|
|
|
2024-02-24 20:16:04 +08:00
|
|
|
export function extractYoutubeVideoId(url: string) {
|
2023-01-21 20:37:55 +08:00
|
|
|
let match = url.match(/youtube\.com\/watch\?v=([^&]+)/);
|
|
|
|
if (match) {
|
|
|
|
return match[1];
|
|
|
|
}
|
|
|
|
match = url.match(/youtu.be\/([^&]+)/);
|
|
|
|
if (match) {
|
|
|
|
return match[1];
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2023-05-24 02:53:53 +08:00
|
|
|
export async function embedWidget(
|
2023-01-21 20:37:55 +08:00
|
|
|
bodyText: string,
|
2023-05-24 02:53:53 +08:00
|
|
|
): Promise<WidgetContent> {
|
2023-01-21 20:37:55 +08:00
|
|
|
try {
|
2023-05-24 02:53:53 +08:00
|
|
|
const data: EmbedConfig = await YAML.parse(bodyText) as any;
|
2023-01-21 20:37:55 +08:00
|
|
|
let url = data.url;
|
|
|
|
const youtubeVideoId = extractYoutubeVideoId(url);
|
|
|
|
if (youtubeVideoId) {
|
|
|
|
url = `https://www.youtube.com/embed/${youtubeVideoId}`;
|
|
|
|
// Sensible video defaults
|
|
|
|
data.width = data.width || 560;
|
|
|
|
data.height = data.height || 315;
|
|
|
|
}
|
|
|
|
return {
|
|
|
|
url,
|
|
|
|
height: data.height,
|
|
|
|
width: data.width,
|
|
|
|
};
|
|
|
|
} catch (e: any) {
|
|
|
|
return {
|
|
|
|
html: `ERROR: Could not parse body as YAML: ${e.message}`,
|
|
|
|
script: "",
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|