Compare commits

..

2 Commits

9 changed files with 82 additions and 5294 deletions

View File

@ -1,31 +0,0 @@
name: Build
run-name: CI/CD website
on:
push:
branches:
- main
- dev
pull_request:
types: [opened, synchronize, reopened]
branches:
- main
- dev
jobs:
build-check:
runs-on: ubuntu-latest
steps:
- name: Check out repository code
uses: actions/checkout@v4
- name: Use Node.js
uses: actions/setup-node@v4
with:
node-version: '24.x'
- name: Install dependencies
run: |
cd banquise-website
npm ci
- name: Building
run: |
cd banquise-website
npm run build

4
.gitignore vendored
View File

@ -30,3 +30,7 @@ pnpm-debug.log*
# optional: nix store link if using nix develop # optional: nix store link if using nix develop
.result .result
# optional: lockfiles you don't use
package-lock.json

File diff suppressed because it is too large Load Diff

View File

@ -1,185 +1,103 @@
import React, { useState } from 'react'; import React, { useState } from 'react';
import { Navigation } from './components/layout/Navigation'; import { Navigation } from './components/layout/Navigation';
import { HeroSection } from './components/sections/HeroSection';
import { ServicesSection } from './components/sections/ServicesSection';
import { TechFeaturesSection } from './components/sections/TechFeaturesSection';
import { AboutSection } from './components/sections/AboutSection';
import { Footer } from './components/layout/Footer'; import { Footer } from './components/layout/Footer';
import { HeroSection } from './components/sections/HeroSection';
import { TechFeaturesSection } from './components/sections/TechFeaturesSection';
import { ServicesSection } from './components/sections/ServicesSection';
import { AboutSection } from './components/sections/AboutSection';
import { Popup } from './components/ui/Popup'; import { Popup } from './components/ui/Popup';
import { ScrollToTopButton } from './components/ui/ScrollToTopButton'; import { ScrollToTopButton } from './components/ui/ScrollToTopButton';
import { ParallaxBackground } from './components/ui/ParallaxBackground';
import { URLS } from './config/constants'; import { URLS } from './config/constants';
// Define Service interface directly in App
interface Service { interface Service {
name: string; name: string;
url: string; url: string;
image: string; image: string;
icon: string;
description: string; description: string;
features: string[]; features: string[];
icon: string;
} }
const services = [ const App: React.FC = () => {
// Define services directly in the component with enhanced data
const services: Service[] = [
{ {
name: "Wiki", name: "Wiki",
url: URLS.services.wiki, url: URLS.services.wiki,
image: "/path/to/wiki-image.jpg", image: "/src/assets/iceberg.png",
icon: "📚", icon: "📚",
description: "Plateforme collaborative de documentation technique et de partage de connaissances. Créez, modifiez et organisez vos guides, tutoriels et documentations en équipe avec un système de versioning intégré.", description: "Notre wiki collaboratif est votre centre de documentation technique. Accédez à des guides détaillés, des tutoriels et de la documentation API pour tous nos services.",
features: [ features: [
"Éditeur markdown avancé avec prévisualisation en temps réel", "Documentation collaborative en temps réel",
"Système de versioning pour suivre les modifications", "Guides d'installation détaillés",
"Collaboration en temps réel avec plusieurs contributeurs", "API et références techniques",
"Recherche intelligente dans tous les documents", "Tutoriels pas à pas",
"Templates prédéfinis pour différents types de documentation", "Base de connaissances communautaire",
"Système de commentaires et de révisions", "Recherche avancée intégrée"
"Export PDF et HTML pour partage externe",
"Intégration avec Git pour la sauvegarde"
] ]
}, },
{ {
name: "Gitea", name: "Gitea",
url: URLS.services.gitea, url: URLS.services.gitea,
image: "/path/to/gitea-image.jpg", image: "/src/assets/iceberg.png",
icon: "🔧", icon: "🔧",
description: "Service Git auto-hébergé lightweight et performant pour vos projets de développement. Alternative open-source à GitHub avec toutes les fonctionnalités essentielles pour gérer vos repositories.", description: "Instance Gitea auto-hébergée pour la gestion de vos dépôts Git. Collaborez sur vos projets avec un contrôle total sur votre code source.",
features: [ features: [
"Repositories Git illimités publics et privés", "Dépôts Git illimités",
"Interface web intuitive pour la gestion des projets", "Issues et pull requests",
"Issues et pull requests avec système de review", "Actions CI/CD intégrées",
"Wiki intégré pour chaque projet", "Gestion d'équipes et permissions",
"Actions CI/CD pour l'automatisation", "Interface web intuitive",
"Gestion fine des permissions et des équipes", "Intégration avec outils externes"
"API REST complète pour l'intégration",
"Webhooks pour les notifications externes"
] ]
}, },
{ {
name: "Panel Gaming", name: "Panel",
url: URLS.services.panel, url: URLS.services.panel,
image: "/path/to/panel-image.jpg", image: "/src/assets/iceberg.png",
icon: "🎮", icon: "🎮",
description: "Interface de gestion centralisée pour tous vos serveurs de jeux. Déployez, configurez et surveillez facilement vos serveurs Minecraft, CS2, Garry's Mod et bien d'autres.", description: "Interface de gestion centralisée pour vos serveurs de jeux. Déployez, configurez et surveillez vos serveurs gaming en quelques clics.",
features: [ features: [
"Support de 20+ jeux populaires (Minecraft, CS2, GMod...)", "Déploiement automatisé de serveurs",
"Déploiement en un clic avec templates préconfigurés", "Monitoring en temps réel",
"Console d'administration en temps réel", "Gestion des ressources système",
"Gestion des fichiers avec éditeur intégré", "Interface d'administration web",
"Monitoring des performances et ressources", "Support multi-jeux",
"Système de sauvegarde automatique",
"Planificateur de tâches automatisées"
]
},
{
name: "Pelican",
url: URLS.services.pelican,
image: "/path/to/pelican-image.jpg",
icon: "🐧",
description: "Pelican is the ultimate, free game server control panel offering high flying security.",
features: [
"Gestion de serveurs de jeux avec serveurs dedies (Minecraft, CS2, Palworld...)",
"Déploiement en un clic avec templates préconfigurés",
"Console d'administration en temps réel",
"Gestion des fichiers avec éditeur intégré",
"Monitoring des performances et ressources",
"Système de sauvegarde automatique",
"Planificateur de tâches automatisées"
]
},
{
name: "Intranet",
url: URLS.services.intra,
image: "/path/to/intra-image.jpg",
icon: "🏢",
description: "Espace privé sécurisé de l'association pour centraliser les ressources internes, communications et outils de collaboration entre membres.",
features: [
"Tableau de bord personnalisé pour chaque membre",
"Calendrier des événements et réunions",
"Partage de fichiers sécurisé",
"Forums de discussion privés",
"Annuaire des membres avec profils",
"Système de notifications internes",
"Gestion des projets et tâches",
"Archive des décisions et procès-verbaux"
]
},
{
name: "Mails",
url: URLS.services.mails,
image: "/path/to/mails-image.jpg",
icon: "📧",
description: "Service de messagerie électronique professionnel avec interface web moderne. Bénéficiez d'une adresse email personnalisée @la-banquise.fr avec toutes les fonctionnalités avancées.",
features: [
"Adresses email personnalisées @la-banquise.fr",
"Interface webmail moderne et responsive",
"Filtres anti-spam et antivirus intégrés",
"Contacts et calendrier synchronisés",
"Support IMAP/SMTP pour clients externes",
"Stockage généreux avec archivage",
"Chiffrement des communications",
"Sauvegarde automatique des données" "Sauvegarde automatique des données"
] ]
},
{
name: "Password change",
url: URLS.services.ssp,
image: "/path/to/mails-image.jpg",
icon: "📧",
description: "Password reset.",
features: [
"Interface pour changer votre mot de passe"
]
},
{
name: "Opencloud",
url: URLS.services.opencloud,
image: "/path/to/opencloud-image.jpg",
icon: "☁️",
description: "Plateforme cloud collaborative open-source pour le stockage, le partage et la synchronisation de fichiers. Alternative libre à Google Drive avec contrôle total sur vos données.",
features: [
"Stockage cloud sécurisé et chiffré",
"Synchronisation multi-appareils",
"Partage de fichiers avec liens sécurisés",
"Édition collaborative de documents",
"Versioning automatique des fichiers",
"Applications mobiles natives",
"Intégration avec outils externes",
"Sauvegarde géoredondante des données"
]
} }
]; ];
const App: React.FC = () => {
const [selectedService, setSelectedService] = useState<Service | null>(null); const [selectedService, setSelectedService] = useState<Service | null>(null);
const [openAccordion, setOpenAccordion] = useState<string | null>(null);
// Inline accordion logic
const [openAccordion, setOpenAccordion] = useState<string | null>(null);
const toggleAccordion = (title: string) => { const toggleAccordion = (title: string) => {
setOpenAccordion(openAccordion === title ? null : title); setOpenAccordion(openAccordion === title ? null : title);
}; };
return ( return (
<div className="min-h-screen bg-gradient-to-b from-banquise-blue-dark via-banquise-blue-dark/95 to-banquise-blue-dark text-white overflow-x-hidden relative"> <div className="flex flex-col min-h-screen w-full">
{/* Background Effects */}
<ParallaxBackground />
{/* Main Content */}
<div className="relative z-10">
<Navigation /> <Navigation />
<HeroSection />
<ServicesSection services={services} onServiceClick={setSelectedService} />
<TechFeaturesSection />
<AboutSection openAccordion={openAccordion} toggleAccordion={toggleAccordion} />
<Footer />
</div>
{/* UI Components */} <main className="flex-1 flex flex-col overflow-x-hidden overflow-y-auto">
<div className="relative flex-1 bg-ocean-gradient w-full min-h-screen flex flex-col justify-start items-center overflow-x-hidden">
<HeroSection />
<TechFeaturesSection />
<ServicesSection services={services} onServiceClick={setSelectedService} />
<AboutSection openAccordion={openAccordion} toggleAccordion={toggleAccordion} />
</div>
</main>
<Footer />
{/* Bouton de retour en haut */}
<ScrollToTopButton /> <ScrollToTopButton />
{selectedService && ( {selectedService && (
<Popup <Popup service={selectedService} onClose={() => setSelectedService(null)} />
service={selectedService}
onClose={() => setSelectedService(null)}
/>
)} )}
</div> </div>
); );

View File

@ -24,26 +24,6 @@ export const Footer: React.FC = () => (
Panel Panel
</a> </a>
</li> </li>
<li>
<a href={URLS.services.pelican} className="text-banquise-gray/80 no-underline transition-all duration-200 inline-flex items-center hover:text-banquise-gray hover:translate-x-1 text-sm sm:text-base">
Pelican
</a>
</li>
<li>
<a href={URLS.services.intra} className="text-banquise-gray/80 no-underline transition-all duration-200 inline-flex items-center hover:text-banquise-gray hover:translate-x-1 text-sm sm:text-base">
Intranet
</a>
</li>
<li>
<a href={URLS.services.mails} className="text-banquise-gray/80 no-underline transition-all duration-200 inline-flex items-center hover:text-banquise-gray hover:translate-x-1 text-sm sm:text-base">
Webmail
</a>
</li>
<li>
<a href={URLS.services.opencloud} className="text-banquise-gray/80 no-underline transition-all duration-200 inline-flex items-center hover:text-banquise-gray hover:translate-x-1 text-sm sm:text-base">
OpenCloud
</a>
</li>
</ul> </ul>
</div> </div>

View File

@ -80,38 +80,6 @@ export const AboutSection: React.FC<AboutSectionProps> = ({ openAccordion, toggl
<p className="text-banquise-gray/80 text-sm">Interface de gestion pour serveurs de jeux</p> <p className="text-banquise-gray/80 text-sm">Interface de gestion pour serveurs de jeux</p>
</div> </div>
</div> </div>
<div className={`flex items-start space-x-4 p-4 ${commonStyles.gradients.card} rounded-xl ${commonStyles.cards.base}`}>
<div className={`${commonStyles.icons.small} ${commonStyles.gradients.primaryBr} font-bold`}>🐧</div>
<div>
<h4 className="font-semibold text-banquise-gray mb-1">Pelican</h4>
<p className="text-banquise-gray/80 text-sm">Générateur de sites statiques</p>
</div>
</div>
<div className={`flex items-start space-x-4 p-4 ${commonStyles.gradients.card} rounded-xl ${commonStyles.cards.base}`}>
<div className={`${commonStyles.icons.small} ${commonStyles.gradients.primaryBr} font-bold`}>🏢</div>
<div>
<h4 className="font-semibold text-banquise-gray mb-1">Intranet</h4>
<p className="text-banquise-gray/80 text-sm">Espace privé de l'association</p>
</div>
</div>
<div className={`flex items-start space-x-4 p-4 ${commonStyles.gradients.card} rounded-xl ${commonStyles.cards.base}`}>
<div className={`${commonStyles.icons.small} ${commonStyles.gradients.primaryBr} font-bold`}>📧</div>
<div>
<h4 className="font-semibold text-banquise-gray mb-1">Webmail</h4>
<p className="text-banquise-gray/80 text-sm">Service de messagerie électronique</p>
</div>
</div>
<div className={`flex items-start space-x-4 p-4 ${commonStyles.gradients.card} rounded-xl ${commonStyles.cards.base}`}>
<div className={`${commonStyles.icons.small} ${commonStyles.gradients.primaryBr} font-bold`}></div>
<div>
<h4 className="font-semibold text-banquise-gray mb-1">OpenCloud</h4>
<p className="text-banquise-gray/80 text-sm">Plateforme cloud collaborative</p>
</div>
</div>
</div> </div>
<p className={`${commonStyles.text.muted} mt-4`}> <p className={`${commonStyles.text.muted} mt-4`}>
Tous nos services sont maintenus avec soin et régulièrement mis à jour pour garantir une expérience optimale. Tous nos services sont maintenus avec soin et régulièrement mis à jour pour garantir une expérience optimale.

View File

@ -1,6 +1,6 @@
import React from 'react'; import React from 'react';
// Update the Service interface to match your actual service objects // Declare the Service interface here
interface Service { interface Service {
name: string; name: string;
url: string; url: string;
@ -13,7 +13,6 @@ interface Service {
// Define interface directly in the component file // Define interface directly in the component file
interface ServicesSectionProps { interface ServicesSectionProps {
services: Service[]; services: Service[];
onServiceClick: (service: Service) => void; onServiceClick: (service: Service) => void;
} }

View File

@ -3,15 +3,10 @@ export const URLS = {
wiki: "https://wiki.la-banquise.fr", wiki: "https://wiki.la-banquise.fr",
gitea: "https://git.la-banquise.fr", gitea: "https://git.la-banquise.fr",
panel: "https://panel.la-banquise.fr", panel: "https://panel.la-banquise.fr",
auth: "https://auth.la-banquise.fr", auth: "https://auth.la-banquise.fr"
pelican: "https://pelican.la-banquise.fr",
intra: "https://intra.la-banquise.fr",
mails: "https://mails.la-banquise.fr",
opencloud: "https://opencloud.la-banquise.fr",
ssp: "https://ssp.la-banquise.fr"
}, },
social: { social: {
discord: "https://discord.gg/QQWwzX5ptY" discord: "https://discord.gg/labanquise"
}, },
contact: { contact: {
email: "mailto:contact@la-banquise.fr" email: "mailto:contact@la-banquise.fr"

6
package-lock.json generated
View File

@ -1,6 +0,0 @@
{
"name": "website-front",
"lockfileVersion": 3,
"requires": true,
"packages": {}
}