Інтеграція Daily.co для відеодзвінків на сайті

Наша компанія займається розробкою, підтримкою та обслуговуванням сайтів будь-якої складності. Від простих односторінкових сайтів до масштабних кластерних систем, побудованих на мікро сервісах. Досвід розробників підтверджено сертифікатами від вендорів.

Розробка та обслуговування будь-яких видів сайтів:

Інформаційні сайти або веб-програми
Сайти візитки, landing page, корпоративні сайти, онлайн каталоги, квіз, промо-сайти, блоги, ресурси новин, інформаційні портали, форуми, агрегатори
Сайти або веб-програми електронної комерції
Інтернет-магазини, B2B-портали, маркетплейси, онлайн-обмінники, кешбек-сайти, біржі, дропшиппінг-платформи, парсери товарів
Веб-програми для управління бізнес-процесами
CRM-системи, ERP-системи, корпоративні портали, системи управління виробництвом, парсери інформації
Сайти або веб-програми електронних послуг
Дошки оголошень, онлайн-школи, онлайн-кінотеатри, конструктори сайтів, портали надання електронних послуг, відеохостинги, тематичні портали

Це лише деякі з технічних типів сайтів, з якими ми працюємо, і кожен із них може мати свої специфічні особливості та функціональність, а також бути адаптованим під конкретні потреби та цілі клієнта.

Пропоновані послуги
Показано 1 з 1 послугУсі 2065 послуг
Інтеграція Daily.co для відеодзвінків на сайті
Середня
~3-5 робочих днів
Часті питання

Наші компетенції:

Етапи розробки

Останні роботи

  • image_website-b2b-advance_0.png
    Розробка сайту компанії B2B ADVANCE
    1262
  • image_web-applications_feedme_466_0.webp
    Розробка веб-додатків для компанії FEEDME
    1171
  • image_websites_belfingroup_462_0.webp
    Розробка веб-сайту для компанії БЕЛФІНГРУП
    874
  • image_ecommerce_furnoro_435_0.webp
    Розробка інтернет магазину для компанії FURNORO
    1094
  • image_crm_enviok_479_0.webp
    Розробка веб-додатків для компанії Enviok
    831
  • image_bitrix-bitrix-24-1c_fixper_448_0.png
    Розробка веб-сайту для компанії ФІКСПЕР
    851

Інтеграція Daily.co для відеозвонків на веб-сайті

Daily.co надає WebRTC-інфраструктуру з простим JavaScript SDK. Ви створюєте комнату через REST API, передаєте URL користувачу — він відкриває відеозвонок прямо в браузері без установки приложення. Підходить для відеоконсультацій, support-чатів, навчання.

Створення комнати через REST API

const DAILY_API_KEY = process.env.DAILY_API_KEY;

async function createRoom(options: {
  name?: string;
  expiresInMinutes?: number;
  maxParticipants?: number;
}): Promise<{ url: string; name: string }> {
  const response = await fetch('https://api.daily.co/v1/rooms', {
    method: 'POST',
    headers: {
      'Authorization': `Bearer ${DAILY_API_KEY}`,
      'Content-Type': 'application/json',
    },
    body: JSON.stringify({
      name: options.name ?? `room-${Date.now()}`,
      properties: {
        exp: Math.floor(Date.now() / 1000) + (options.expiresInMinutes ?? 60) * 60,
        max_participants: options.maxParticipants ?? 10,
        enable_screenshare: true,
        enable_chat: true,
        enable_recording: false,
        start_video_off: false,
        start_audio_off: false,
      },
    }),
  });

  const room = await response.json();
  return { url: room.url, name: room.name };
}

// API для створення сесії
app.post('/api/video/room', authenticate, async (req, res) => {
  const { consultationId } = req.body;
  const room = await createRoom({
    name: `consultation-${consultationId}`,
    expiresInMinutes: 90,
    maxParticipants: 2,
  });

  await db.consultations.update(consultationId, { roomUrl: room.url });
  res.json({ url: room.url });
});

Токен учасника

Для приватних комнат потрібен meeting token — інакше в комнату попадеться будь-хто з URL:

async function createMeetingToken(roomName: string, participantName: string, isOwner = false) {
  const response = await fetch('https://api.daily.co/v1/meeting-tokens', {
    method: 'POST',
    headers: {
      'Authorization': `Bearer ${DAILY_API_KEY}`,
      'Content-Type': 'application/json',
    },
    body: JSON.stringify({
      properties: {
        room_name: roomName,
        user_name: participantName,
        is_owner: isOwner,  // власник може видаляти інших учасників
        exp: Math.floor(Date.now() / 1000) + 90 * 60,
        enable_recording: isOwner,
      },
    }),
  });

  const { token } = await response.json();
  return token;
}

React компонент з Daily JS SDK

npm install @daily-co/daily-js
import DailyIframe from '@daily-co/daily-js';
import { useEffect, useRef, useState } from 'react';

interface VideoCallProps {
  roomUrl: string;
  token: string;
  userName: string;
  onLeave?: () => void;
}

function VideoCall({ roomUrl, token, userName, onLeave }: VideoCallProps) {
  const callRef = useRef<ReturnType<typeof DailyIframe.createFrame> | null>(null);
  const containerRef = useRef<HTMLDivElement>(null);
  const [status, setStatus] = useState<'idle' | 'joining' | 'joined' | 'left'>('idle');

  useEffect(() => {
    if (!containerRef.current) return;

    const call = DailyIframe.createFrame(containerRef.current, {
      showLeaveButton: true,
      showFullscreenButton: true,
      iframeStyle: { width: '100%', height: '100%', border: 'none', borderRadius: '12px' },
    });

    callRef.current = call;

    call.on('joining-meeting', () => setStatus('joining'));
    call.on('joined-meeting', () => setStatus('joined'));
    call.on('left-meeting', () => {
      setStatus('left');
      onLeave?.();
    });
    call.on('error', (err) => console.error('Daily error:', err));

    call.join({ url: roomUrl, token, userName });

    return () => {
      call.destroy();
    };
  }, [roomUrl, token]);

  return (
    <div className="relative" style={{ height: 600 }}>
      {status === 'joining' && (
        <div className="absolute inset-0 flex items-center justify-center bg-gray-900 rounded-xl z-10">
          <p className="text-white">Підключення...</p>
        </div>
      )}
      {status === 'left' && (
        <div className="absolute inset-0 flex items-center justify-center bg-gray-900 rounded-xl z-10">
          <p className="text-white text-lg">Звонок завершено</p>
        </div>
      )}
      <div ref={containerRef} className="w-full h-full" />
    </div>
  );
}

Webhooks для подій

Daily.co відправляє події на ваш сервер:

app.post('/api/webhooks/daily', async (req, res) => {
  const { event_type, payload } = req.body;

  switch (event_type) {
    case 'meeting.started':
      await db.videoSessions.markStarted(payload.room.name);
      break;
    case 'meeting.ended':
      await db.videoSessions.markEnded(payload.room.name, {
        duration: payload.meeting_duration,
      });
      break;
    case 'participant.joined':
      await db.videoSessions.addParticipant(payload.room.name, payload.participant.user_name);
      break;
  }

  res.status(200).end();
});

Терміни

Базова інтеграція Daily.co з створенням комнати та iframe — 1–2 дні. З токенами, webhooks та записом — 3–4 дні.