mirror of
https://github.com/LuanRT/YouTube.js.git
synced 2026-06-17 03:22:15 +00:00
71 lines
2.2 KiB
TypeScript
71 lines
2.2 KiB
TypeScript
import NavigationEndpoint from '../NavigationEndpoint.js';
|
|
import { escape, type Run } from './Text.js';
|
|
import type { RawNode } from '../../index.js';
|
|
|
|
export default class TextRun implements Run {
|
|
text: string;
|
|
endpoint?: NavigationEndpoint;
|
|
bold: boolean;
|
|
italics: boolean;
|
|
strikethrough: boolean;
|
|
deemphasize: boolean;
|
|
attachment;
|
|
|
|
constructor(data: RawNode) {
|
|
this.text = data.text;
|
|
this.bold = Boolean(data.bold);
|
|
this.italics = Boolean(data.italics);
|
|
this.strikethrough = Boolean(data.strikethrough);
|
|
this.deemphasize = Boolean(data.deemphasize);
|
|
|
|
if (Reflect.has(data, 'navigationEndpoint')) {
|
|
this.endpoint = new NavigationEndpoint(data.navigationEndpoint);
|
|
}
|
|
|
|
this.attachment = data.attachment;
|
|
}
|
|
|
|
toString(): string {
|
|
return this.text;
|
|
}
|
|
|
|
toHTML(): string {
|
|
const tags: string[] = [];
|
|
|
|
if (this.bold) tags.push('b');
|
|
if (this.italics) tags.push('i');
|
|
if (this.strikethrough) tags.push('s');
|
|
if (this.deemphasize) tags.push('small');
|
|
|
|
if (!this.text?.length)
|
|
return '';
|
|
|
|
const escaped_text = escape(this.text);
|
|
const styled_text = tags.map((tag) => `<${tag}>`).join('') + escaped_text + tags.map((tag) => `</${tag}>`).join('');
|
|
const wrapped_text = `<span style="white-space: pre-wrap;">${styled_text}</span>`;
|
|
|
|
if (this.attachment) {
|
|
if (this.attachment.element.type.imageType.image.sources.length) {
|
|
if (this.endpoint) {
|
|
const { url } = this.attachment.element.type.imageType.image.sources[0];
|
|
|
|
let image_el = '';
|
|
|
|
if (url) {
|
|
image_el = `<img src="${url}" style="vertical-align: middle; height: ${this.attachment.element.properties.layoutProperties.height.value}px; width: ${this.attachment.element.properties.layoutProperties.width.value}px;" alt="">`;
|
|
}
|
|
|
|
const nav_url = this.endpoint.toURL();
|
|
if (nav_url) return `<a href="${nav_url}" class="yt-ch-link">${image_el}${wrapped_text}</a>`;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (this.endpoint) {
|
|
const url = this.endpoint.toURL();
|
|
if (url) return `<a href="${url}">${wrapped_text}</a>`;
|
|
}
|
|
|
|
return wrapped_text;
|
|
}
|
|
} |