From 44d1333b4b98f02410875335b7cce8fa0fe526bf Mon Sep 17 00:00:00 2001 From: Webber Qian <32994870+findwei@users.noreply.github.com> Date: Fri, 15 Nov 2024 11:07:09 +0800 Subject: [PATCH] feat: new router logrocket (#17533) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * feat: new router logrocket * fix: router * fix:article edit * fix:remove unused file --------- Co-authored-by: 钱巍 --- lib/routes/logrocket/index.ts | 71 +++++++++++++++++++++++++++++++ lib/routes/logrocket/namespace.ts | 7 +++ 2 files changed, 78 insertions(+) create mode 100644 lib/routes/logrocket/index.ts create mode 100644 lib/routes/logrocket/namespace.ts diff --git a/lib/routes/logrocket/index.ts b/lib/routes/logrocket/index.ts new file mode 100644 index 00000000000000..16bb17de4b0406 --- /dev/null +++ b/lib/routes/logrocket/index.ts @@ -0,0 +1,71 @@ +import { parseDate } from '@/utils/parse-date'; +import ofetch from '@/utils/ofetch'; // 统一使用的请求库 +import { load } from 'cheerio'; // 类似 jQuery 的 API HTML 解析器 +import { Route } from '@/types'; +import cache from '@/utils/cache'; +// import { getCurrentPath } from '@/utils/helpers'; +// import { art } from '@/utils/render'; +// import path from 'node:path'; +// const __dirname = getCurrentPath(import.meta.url); +export const route: Route = { + path: '/:type', + categories: ['blog'], + example: '/dev', + parameters: { type: 'dev | product-management | ux-design' }, + radar: [ + { + source: ['blog.logrocket.com'], + }, + ], + name: 'blog.logrocket', + maintainers: ['findwei'], + handler, + url: 'blog.logrocket.com/', +}; +async function handler(ctx) { + const type = ctx.req.param('type'); + const link = 'https://blog.logrocket.com/'; + let title = 'Dev'; + if (type === 'product-management') { + title = 'Product Management'; + } else if (type === 'ux-design') { + title = 'UX Design'; + } + const response = await ofetch(`${link}${type}`); + const $ = load(response); + const list = $('div.post-list .post-card') + .toArray() + .map((item) => { + item = $(item); + const a = item.find('a').first(); + const title = item.find('.post-card-title').first(); + return { + title: title.text(), + link: a.attr('href'), + pubDate: parseDate(item.find('.post-card-author-name').next().text().split(' ⋅ ')[0], 'MMM D, YYYY'), + author: item.find('.post-card-author-name').text(), + }; + }); + const items = await Promise.all( + list.map((item) => + cache.tryGet(item.link, async () => { + const response = await ofetch(item.link); + const $ = load(response); + // + $('div.content-max-width .sidebar-container div.code-block').remove(); + item.description = $('div.content-max-width .sidebar-container').html(); + // item.description = art(path.join(__dirname, 'templates/description.art'), { + // // header: $('#post-header').html(), + // description: $('div.content-max-width .the-content-container').remove('.lr-content div.code-block.code-block-77').remove('.lr-content .code-block.code-block-57').html(), + // }); + return item; + }) + ) + ); + return { + title: `logrocket-${title}`, + link, + description: `logrocket-${title}`, + item: items, + }; +} diff --git a/lib/routes/logrocket/namespace.ts b/lib/routes/logrocket/namespace.ts new file mode 100644 index 00000000000000..3a091ddc538e6b --- /dev/null +++ b/lib/routes/logrocket/namespace.ts @@ -0,0 +1,7 @@ +import type { Namespace } from '@/types'; + +export const namespace: Namespace = { + name: 'logrocket blog', + url: 'blog.logrocket.com', + lang: 'en', +};