feat: Initialize frontend with React, Vite, and Tailwind CSS
- Set up main entry point for React application. - Create About, Home, NotFound, Privacy, and Terms pages with SEO support. - Implement API service for file uploads and task management. - Add global styles using Tailwind CSS. - Create utility functions for SEO and text processing. - Configure Vite for development and production builds. - Set up Nginx configuration for serving frontend and backend. - Add scripts for cleanup of expired files and sitemap generation. - Implement deployment script for production environment.
This commit is contained in:
20
frontend/src/hooks/useDirection.ts
Normal file
20
frontend/src/hooks/useDirection.ts
Normal file
@@ -0,0 +1,20 @@
|
||||
import { useEffect } from 'react';
|
||||
import { useTranslation } from 'react-i18next';
|
||||
|
||||
/**
|
||||
* Hook that manages the HTML dir attribute based on current language.
|
||||
*/
|
||||
export function useDirection() {
|
||||
const { i18n } = useTranslation();
|
||||
const isRTL = i18n.language === 'ar';
|
||||
|
||||
useEffect(() => {
|
||||
const dir = isRTL ? 'rtl' : 'ltr';
|
||||
const lang = i18n.language;
|
||||
|
||||
document.documentElement.setAttribute('dir', dir);
|
||||
document.documentElement.setAttribute('lang', lang);
|
||||
}, [i18n.language, isRTL]);
|
||||
|
||||
return { isRTL, language: i18n.language };
|
||||
}
|
||||
Reference in New Issue
Block a user