/** * 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>} */ 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;