All files / lib/api/service qrCodeService.ts

100% Statements 5/5
100% Branches 0/0
100% Functions 1/1
100% Lines 5/5

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 262x           2x   2x                 4x 4x              
import {fetchApi} from '@/lib/api/core/fetchWrappers';
import QRCode from "@/type/achat/qrCode";
 
/**
 * Service pour la gestion des QR codes des tickets
 */
export class QrCodeService {
  /** Chemin de base pour les endpoints des QR codes */
  private static readonly BASE_PATH = '/qr_code_service';
 
  /**
   * Récupère ou génère le QR code d'un ticket client
   * @param _ticketID - ID du ticket pour lequel générer le QR code
   * @returns Promise<QRCode> - Le QR code généré ou existant
   * @throws Error - En cas d'erreur de l'API ou si le ticket n'existe pas
   */
  static async getQrCodeClient(_ticketID: number): Promise<QRCode> {
    const url = `${this.BASE_PATH}/create_by_ticket/`;
    return fetchApi<QRCode>(url, {
      method: 'POST',
      headers: { 'Content-Type': 'application/json' },
      body: JSON.stringify({"ticket_id": _ticketID}),
    }, true);
  }
}