52 lines
1.9 KiB
JavaScript
52 lines
1.9 KiB
JavaScript
/**
|
|
* Minimal Dailymotion provider handler
|
|
*/
|
|
const handler = {
|
|
id: 'dm',
|
|
label: 'Dailymotion',
|
|
/**
|
|
* @param {string} q
|
|
* @param {{ limit: number, page?: number, sort?: 'relevance'|'date'|'views' }} opts
|
|
* @returns {Promise<Array<any>>}
|
|
*/
|
|
async search(q, opts) {
|
|
const { limit = 10, page = 1, sort = 'relevance' } = opts || {};
|
|
try {
|
|
const response = await fetch(
|
|
`https://api.dailymotion.com/videos?` +
|
|
new URLSearchParams({
|
|
search: q,
|
|
limit: Math.min(limit, 100).toString(),
|
|
page: Math.max(1, Number(page || 1)).toString(),
|
|
// Map our sort to Dailymotion API sort: relevance | visited (views) | recent (date)
|
|
sort: (sort === 'date' ? 'recent' : (sort === 'views' ? 'visited' : 'relevance')),
|
|
fields: 'id,title,thumbnail_url,thumbnail_360_url,thumbnail_480_url,thumbnail_720_url,duration,views_total,owner.screenname,owner.avatar_80_url,created_time'
|
|
})
|
|
);
|
|
|
|
if (!response.ok) {
|
|
throw new Error(`Dailymotion API error: ${response.status}`);
|
|
}
|
|
|
|
const data = await response.json();
|
|
|
|
return (data.list || []).map(item => ({
|
|
title: item.title || '',
|
|
id: item.id || '',
|
|
url: `https://www.dailymotion.com/video/${item.id}`,
|
|
thumbnail: item.thumbnail_720_url || item.thumbnail_480_url || item.thumbnail_360_url || item.thumbnail_url || '',
|
|
uploaderName: item['owner.screenname'] || item['owner.username'] || '',
|
|
uploaderAvatar: item['owner.avatar_80_url'] || '',
|
|
duration: Number(item.duration || 0),
|
|
views: Number(item.views_total || 0),
|
|
uploadedDate: item.created_time ? new Date(item.created_time * 1000).toISOString() : '',
|
|
type: 'video'
|
|
}));
|
|
} catch (error) {
|
|
console.error('Dailymotion search error:', error);
|
|
return [];
|
|
}
|
|
}
|
|
};
|
|
export default handler;
|