From 9aac44236c84f17b14ce35e358a87389766e2743 Mon Sep 17 00:00:00 2001 From: Chocobozzz Date: Fri, 14 Dec 2018 15:49:36 +0100 Subject: Add video title/description when rendering html --- server/lib/client-html.ts | 51 ++++++++++++++++++++++++++++++----------------- 1 file changed, 33 insertions(+), 18 deletions(-) (limited to 'server/lib/client-html.ts') diff --git a/server/lib/client-html.ts b/server/lib/client-html.ts index fc013e0c3..2db3f8a34 100644 --- a/server/lib/client-html.ts +++ b/server/lib/client-html.ts @@ -18,21 +18,13 @@ export class ClientHtml { ClientHtml.htmlCache = {} } - static async getIndexHTML (req: express.Request, res: express.Response, paramLang?: string) { - const path = ClientHtml.getIndexPath(req, res, paramLang) - if (ClientHtml.htmlCache[path]) return ClientHtml.htmlCache[path] - - const buffer = await readFile(path) + static async getDefaultHTMLPage (req: express.Request, res: express.Response, paramLang?: string) { + const html = await ClientHtml.getIndexHTML(req, res, paramLang) - let html = buffer.toString() - - html = ClientHtml.addTitleTag(html) - html = ClientHtml.addDescriptionTag(html) - html = ClientHtml.addCustomCSS(html) + let customHtml = ClientHtml.addTitleTag(html) + customHtml = ClientHtml.addDescriptionTag(customHtml) - ClientHtml.htmlCache[path] = html - - return html + return customHtml } static async getWatchHTMLPage (videoId: string, req: express.Request, res: express.Response) { @@ -55,7 +47,26 @@ export class ClientHtml { return ClientHtml.getIndexHTML(req, res) } - return ClientHtml.addOpenGraphAndOEmbedTags(html, video) + let customHtml = ClientHtml.addTitleTag(html, escapeHTML(video.name)) + customHtml = ClientHtml.addDescriptionTag(customHtml, escapeHTML(video.description)) + customHtml = ClientHtml.addOpenGraphAndOEmbedTags(customHtml, video) + + return customHtml + } + + private static async getIndexHTML (req: express.Request, res: express.Response, paramLang?: string) { + const path = ClientHtml.getIndexPath(req, res, paramLang) + if (ClientHtml.htmlCache[path]) return ClientHtml.htmlCache[path] + + const buffer = await readFile(path) + + let html = buffer.toString() + + html = ClientHtml.addCustomCSS(html) + + ClientHtml.htmlCache[path] = html + + return html } private static getIndexPath (req: express.Request, res: express.Response, paramLang?: string) { @@ -81,14 +92,18 @@ export class ClientHtml { return join(__dirname, '../../../client/dist/' + buildFileLocale(lang) + '/index.html') } - private static addTitleTag (htmlStringPage: string) { - const titleTag = '' + CONFIG.INSTANCE.NAME + '' + private static addTitleTag (htmlStringPage: string, title?: string) { + let text = title || CONFIG.INSTANCE.NAME + if (title) text += ` - ${CONFIG.INSTANCE.NAME}` + + const titleTag = `${text}` return htmlStringPage.replace(CUSTOM_HTML_TAG_COMMENTS.TITLE, titleTag) } - private static addDescriptionTag (htmlStringPage: string) { - const descriptionTag = `` + private static addDescriptionTag (htmlStringPage: string, description?: string) { + const content = description || CONFIG.INSTANCE.SHORT_DESCRIPTION + const descriptionTag = `` return htmlStringPage.replace(CUSTOM_HTML_TAG_COMMENTS.DESCRIPTION, descriptionTag) } -- cgit v1.2.3