rsshub
Version:
Make RSS Great Again!
72 lines (67 loc) • 2.12 kB
text/typescript
import { Route } from '@/types';
import got from '@/utils/got';
import { art } from '@/utils/render';
import path from 'node:path';
import { load } from 'cheerio';
const host = 'https://www.snowpeak.com';
export const route: Route = {
path: '/us/new-arrivals',
categories: ['shopping'],
example: '/snowpeak/us/new-arrivals',
parameters: {},
features: {
requireConfig: false,
requirePuppeteer: false,
antiCrawler: false,
supportBT: false,
supportPodcast: false,
supportScihub: false,
},
radar: [
{
source: ['snowpeak.com/collections/new-arrivals', 'snowpeak.com/'],
},
],
name: 'New Arrivals(USA)',
maintainers: ['EthanWng97'],
handler,
url: 'snowpeak.com/collections/new-arrivals',
};
async function handler() {
const url = `${host}/collections/new-arrivals`;
const response = await got({
method: 'get',
url,
});
const data = response.data;
const $ = load(data);
const list = $('.element.product-tile')
.toArray()
.map((element) => {
const data = {};
const product = $(element).find('.product-data').data('product');
data.title = product.title;
data.link = `${host}/products/${product.handle}`;
data.pubDate = new Date(product.published_at).toUTCString();
data.category = product.tags;
data.variants = product.variants.map((item) => item.name);
data.description =
product.description +
art(path.join(__dirname, 'templates/new-arrivals.art'), {
product,
});
return data;
});
return {
title: 'Snow Peak - New Arrivals',
link: `${host}/new-arrivals`,
description: 'Snow Peak - New Arrivals',
item: list.map((item) => ({
title: item.title,
category: item.category,
description: item.description,
pubDate: item.pubDate,
link: item.link,
})),
};
}