Files
openccb/web/experience/src/hooks/useCourseLanguage.ts
T
Nurfog e72f479639 feat: add PWA support with service worker, offline sync, and connectivity banners
- Added PWA icons for 192x192 and 512x512 resolutions.
- Implemented service worker (sw.js) for caching static assets and handling fetch requests.
- Created ConnectivityBanner component to notify users of online/offline status.
- Developed OfflineSyncPanel component to manage and display offline sync status.
- Introduced PwaInstallPrompt component to prompt users for PWA installation.
- Added PwaRegistration component to handle service worker registration and online event handling.
- Created AdminAiAuditPage for AI audit logs with filtering and review functionality.
- Developed AdminDataEthicsPage to display AI data ethics summary and recent events.
2026-04-24 09:59:57 -04:00

108 lines
3.4 KiB
TypeScript

"use client";
import { useEffect, useState, useCallback } from 'react';
import { useTranslation } from '@/context/I18nContext';
interface CourseLanguageConfig {
language_setting: 'auto' | 'fixed';
fixed_language: string | null;
}
/**
* Hook para manejar el idioma específico de un curso
*
* - Si el curso está en modo 'auto', usa el idioma del usuario
* - Si el curso está en modo 'fixed', usa el idioma fijo del curso
*
* @param courseId - ID del curso actual
* @returns El idioma que debe usarse para este curso
*/
export function useCourseLanguage(courseId: string | null) {
const { language: userLanguage } = useTranslation();
const [courseLanguage, setCourseLanguage] = useState<string>(userLanguage);
const [isLoading, setIsLoading] = useState(true);
const [config, setConfig] = useState<CourseLanguageConfig | null>(null);
// Función para cargar la configuración de idioma del curso
const loadCourseLanguageConfig = useCallback(async () => {
if (!courseId) {
setCourseLanguage(userLanguage);
setIsLoading(false);
return;
}
try {
// Importar dinámicamente para evitar circular dependencies
const { lmsApi } = await import('@/lib/api');
const data = await lmsApi.getCourseLanguageConfig(courseId);
setConfig(data);
// Determinar qué idioma usar
if (data.language_setting === 'fixed' && data.fixed_language) {
setCourseLanguage(data.fixed_language);
} else {
// Modo 'auto' o sin configuración: usar idioma del usuario
setCourseLanguage(userLanguage);
}
} catch (error) {
console.error('Error loading course language config:', error);
// Fallback: usar idioma del usuario
setCourseLanguage(userLanguage);
} finally {
setIsLoading(false);
}
}, [courseId, userLanguage]);
// Cargar configuración cuando cambia el courseId
useEffect(() => {
loadCourseLanguageConfig();
}, [loadCourseLanguageConfig]);
// Función para verificar si el curso usa idioma fijo
const isFixedLanguage = useCallback(() => {
return config?.language_setting === 'fixed';
}, [config]);
// Función para obtener el idioma actual (curso o usuario)
const getCurrentLanguage = useCallback(() => {
return courseLanguage;
}, [courseLanguage]);
return {
courseLanguage,
isFixedLanguage,
getCurrentLanguage,
isLoading,
refreshConfig: loadCourseLanguageConfig,
};
}
/**
* Hook para cambiar el idioma del usuario (solo funciona si el curso está en modo 'auto')
*
* @param courseId - ID del curso actual
*/
export function useCourseLanguageSwitcher(courseId: string | null) {
const { setLanguage, language } = useTranslation();
const { isFixedLanguage } = useCourseLanguage(courseId);
const canChangeLanguage = !isFixedLanguage();
const changeLanguage = (newLanguage: string) => {
if (canChangeLanguage) {
setLanguage(newLanguage);
} else {
console.warn('Cannot change language: course has fixed language setting');
}
};
return {
currentLanguage: language,
canChangeLanguage,
changeLanguage,
isFixed: isFixedLanguage(),
};
}