Compare commits
15 Commits
cv_dev_con
...
master
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
cd97001cc0 | ||
|
|
dfc4f55709 | ||
|
|
2c8ae62e4b | ||
|
|
eacd26e532 | ||
|
|
8ac697b6e3 | ||
|
|
f43afab585 | ||
|
|
0764207780 | ||
|
|
d040932217 | ||
|
|
c633026376 | ||
|
|
de4be9e248 | ||
|
|
b52842c254 | ||
|
|
5b1ea933f6 | ||
|
|
ecabfcc392 | ||
|
|
d9a6269f13 | ||
|
|
c08dff5171 |
10
.vscode/settings.json
vendored
Normal file
10
.vscode/settings.json
vendored
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
{
|
||||||
|
// Use Prettier as the default formatter for HTML and CSS
|
||||||
|
"editor.defaultFormatter": "esbenp.prettier-vscode",
|
||||||
|
"[html]": {
|
||||||
|
"editor.defaultFormatter": "esbenp.prettier-vscode"
|
||||||
|
},
|
||||||
|
"[css]": {
|
||||||
|
"editor.defaultFormatter": "esbenp.prettier-vscode"
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,4 +1,8 @@
|
|||||||
|
|
||||||
|
html validator : https://validator.w3.org/nu
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
start it with a server, like : `alive-server`
|
start it with a server, like : `alive-server`
|
||||||
- https://www.npmjs.com/package/alive-server
|
- https://www.npmjs.com/package/alive-server
|
||||||
- install : `npm install -g alive-server`
|
- install : `npm install -g alive-server`
|
||||||
|
|||||||
BIN
docs/cvs/CV_Hugo_Lamy_Backend_Embedded_Developer.pdf
Normal file
BIN
docs/cvs/CV_Hugo_Lamy_Backend_Embedded_Developer.pdf
Normal file
Binary file not shown.
BIN
docs/cvs/CV_Hugo_Lamy_Backend_Embedded_Developer_Ats_EN.pdf
Normal file
BIN
docs/cvs/CV_Hugo_Lamy_Backend_Embedded_Developer_Ats_EN.pdf
Normal file
Binary file not shown.
BIN
docs/cvs/CV_Hugo_Lamy_Backend_Embedded_Developer_Ats_FR.pdf
Normal file
BIN
docs/cvs/CV_Hugo_Lamy_Backend_Embedded_Developer_Ats_FR.pdf
Normal file
Binary file not shown.
BIN
docs/cvs/CV_Hugo_Lamy_Backend_Embedded_Developer_EN.pdf
Normal file
BIN
docs/cvs/CV_Hugo_Lamy_Backend_Embedded_Developer_EN.pdf
Normal file
Binary file not shown.
BIN
docs/cvs/CV_Hugo_Lamy_Backend_Embedded_Developer_FR.pdf
Normal file
BIN
docs/cvs/CV_Hugo_Lamy_Backend_Embedded_Developer_FR.pdf
Normal file
Binary file not shown.
Binary file not shown.
Binary file not shown.
705
index.html
705
index.html
@@ -1,25 +1,44 @@
|
|||||||
<!DOCTYPE html>
|
<!doctype html>
|
||||||
<html lang="fr" dir="ltr">
|
<html lang="fr" dir="ltr">
|
||||||
<head>
|
<head>
|
||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8" />
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
|
<meta
|
||||||
|
name="viewport"
|
||||||
|
content="width=device-width, initial-scale=1, maximum-scale=1"
|
||||||
|
/>
|
||||||
<!-- create "fake" favicon : https://stackoverflow.com/questions/1321878/how-to-prevent-favicon-ico-requests -->
|
<!-- create "fake" favicon : https://stackoverflow.com/questions/1321878/how-to-prevent-favicon-ico-requests -->
|
||||||
<link rel="icon" href="data:;base64,iVBORw0KGgo=">
|
<link rel="icon" href="data:;base64,iVBORw0KGgo=" />
|
||||||
<title>hugulumu.fr</title>
|
<title>hugulumu.fr</title>
|
||||||
<meta name="description" content="site web de hugo lamy, developpeur">
|
<meta name="description" content="site web de hugo lamy, developpeur" />
|
||||||
<link href="./styles/reset.css" type="text/css" rel="stylesheet">
|
<link href="./styles/reset.css" type="text/css" rel="stylesheet" />
|
||||||
<link href="./styles/style.css" type="text/css" rel="stylesheet">
|
<link href="./styles/style.css" type="text/css" rel="stylesheet" />
|
||||||
<link href="./styles/global.css" type="text/css" rel="stylesheet">
|
<link href="./styles/global.css" type="text/css" rel="stylesheet" />
|
||||||
<link href="./styles/text.css" type="text/css" rel="stylesheet">
|
<link href="./styles/text.css" type="text/css" rel="stylesheet" />
|
||||||
<link href="./styles/sections.css" type="text/css" rel="stylesheet">
|
<link href="./styles/sections.css" type="text/css" rel="stylesheet" />
|
||||||
<link href="./styles/elements/mouses.css" type="text/css" rel="stylesheet">
|
<link
|
||||||
<link href="./styles/elements/banners.css" type="text/css" rel="stylesheet">
|
href="./styles/elements/mouses.css"
|
||||||
<link href="./styles/elements/title.css" type="text/css" rel="stylesheet">
|
type="text/css"
|
||||||
<link href="./styles/elements/hero.css" type="text/css" rel="stylesheet">
|
rel="stylesheet"
|
||||||
<link href="./styles/elements/projects.css" type="text/css" rel="stylesheet">
|
/>
|
||||||
<link href="./styles/elements/cv.css" type="text/css" rel="stylesheet">
|
<link
|
||||||
<link href="./styles/elements/infos.css" type="text/css" rel="stylesheet">
|
href="./styles/elements/banners.css"
|
||||||
<link href="./styles/elements/language.css" type="text/css" rel="stylesheet">
|
type="text/css"
|
||||||
|
rel="stylesheet"
|
||||||
|
/>
|
||||||
|
<link href="./styles/elements/title.css" type="text/css" rel="stylesheet" />
|
||||||
|
<link href="./styles/elements/hero.css" type="text/css" rel="stylesheet" />
|
||||||
|
<link
|
||||||
|
href="./styles/elements/projects.css"
|
||||||
|
type="text/css"
|
||||||
|
rel="stylesheet"
|
||||||
|
/>
|
||||||
|
<link href="./styles/elements/cv.css" type="text/css" rel="stylesheet" />
|
||||||
|
<link href="./styles/elements/infos.css" type="text/css" rel="stylesheet" />
|
||||||
|
<link
|
||||||
|
href="./styles/elements/language.css"
|
||||||
|
type="text/css"
|
||||||
|
rel="stylesheet"
|
||||||
|
/>
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
<!--
|
<!--
|
||||||
@@ -33,27 +52,32 @@
|
|||||||
-->
|
-->
|
||||||
|
|
||||||
<body id="body">
|
<body id="body">
|
||||||
|
<input type="checkbox" id="language" />
|
||||||
|
|
||||||
<input type="checkbox" id="language">
|
|
||||||
<label id="language_label" for="language">
|
<label id="language_label" for="language">
|
||||||
<span id="fr"><img class="flag" src="./docs/flags/fr_bnw.svg" alt="french flag"></span>
|
<span id="fr"
|
||||||
<span id="en"><img class="flag" src="./docs/flags/gb_bnw.svg" alt="english flag"></span>
|
><img class="flag" src="./docs/flags/fr_bnw.svg" alt="french flag"
|
||||||
|
/></span>
|
||||||
|
<span id="en"
|
||||||
|
><img class="flag" src="./docs/flags/gb_bnw.svg" alt="english flag"
|
||||||
|
/></span>
|
||||||
</label>
|
</label>
|
||||||
|
|
||||||
<!--
|
<!--
|
||||||
I moved this outside the hero section,
|
I moved this outside the hero section,
|
||||||
so that i can change my mind to put it or not without having to change the grid rows height
|
so that i can change my mind to put it or not without having to change the grid rows height
|
||||||
-->
|
-->
|
||||||
<div id="top_banner" class="banner banner_size_0 banner_speed_50 banner_reverse grid_full_width" aria-label="banner delimitation in ASCII art"></div>
|
<div
|
||||||
|
id="top_banner"
|
||||||
|
class="banner banner_size_0 banner_speed_50 banner_reverse grid_full_width"
|
||||||
|
aria-label="banner delimitation in ASCII art"
|
||||||
|
></div>
|
||||||
|
|
||||||
<!--
|
<!--
|
||||||
HERO SECTION
|
HERO SECTION
|
||||||
-->
|
-->
|
||||||
<section class="section hero" id="hero">
|
<section class="section hero" id="hero">
|
||||||
|
|
||||||
<header>
|
<header>
|
||||||
|
<!-- prettier-ignore -->
|
||||||
<h1 aria-label="hugo lamy" id="name" class="title">
|
<h1 aria-label="hugo lamy" id="name" class="title">
|
||||||
<span aria-hidden="true" class="pre pre_small">
|
<span aria-hidden="true" class="pre pre_small">
|
||||||
|
|
||||||
@@ -70,6 +94,7 @@
|
|||||||
|
|
||||||
</span>
|
</span>
|
||||||
</h1>
|
</h1>
|
||||||
|
<!-- prettier-ignore -->
|
||||||
<h1 aria-label="programmeur informatique" id="title" class="title">
|
<h1 aria-label="programmeur informatique" id="title" class="title">
|
||||||
<span aria-hidden="true" class="pre">
|
<span aria-hidden="true" class="pre">
|
||||||
<span class="fr">
|
<span class="fr">
|
||||||
@@ -88,38 +113,279 @@
|
|||||||
</span>
|
</span>
|
||||||
</span>
|
</span>
|
||||||
</h1>
|
</h1>
|
||||||
|
|
||||||
<p class="subtitle">
|
<p class="subtitle">
|
||||||
<span class="fr">méthodique, inventif, curieux</span>
|
<span class="fr">
|
||||||
<span class="en">methodical, inventive, curious</span>
|
Bonjour, je suis un développeur inventif, méthodique, et passionné
|
||||||
|
par l'informatique, et plus particulièrement le libre et l'open
|
||||||
|
source. J'aime explorer de nouvelles solutions techniques et
|
||||||
|
comprendre les systèmes en profondeur :-]
|
||||||
|
</span>
|
||||||
|
<span class="en">
|
||||||
|
Hello, I am a creative, methodical developer with a passion for
|
||||||
|
computer science, particularly free and open-source software. I
|
||||||
|
enjoy exploring new technical solutions and gaining a deep
|
||||||
|
understanding of systems :-]
|
||||||
|
</span>
|
||||||
</p>
|
</p>
|
||||||
</header>
|
</header>
|
||||||
|
|
||||||
<details class="cv margin_top_big">
|
<div class="mouse"><div class="frames mouse_1 pre"></div></div>
|
||||||
<summary>
|
<div
|
||||||
<h2 class="close">
|
class="banner banner_size_3 banner_speed_30 grid_full_width margin_bottom_small"
|
||||||
<span class="fr">voir le CV</span>
|
aria-label="banner delimitation in ASCII art"
|
||||||
<span class="en">see the CV</span>
|
></div>
|
||||||
</h2>
|
</section>
|
||||||
<h2 class="open">
|
|
||||||
<span class="fr">cacher le CV</span>
|
|
||||||
<span class="en">hide the CV</span>
|
|
||||||
</h2>
|
|
||||||
</summary>
|
|
||||||
|
|
||||||
<span class="fr"><a class="cv_download margin_bottom_big" href="docs/hugo_lamy_cv_2024_fr.pdf" target="_blank" rel="noopener noreferrer" title="link to a pdf version of this section CV">télécharger en pdf</a></span>
|
<!--
|
||||||
<span class="en"><a class="cv_download margin_bottom_big" href="docs/hugo_lamy_cv_2024_en.pdf" target="_blank" rel="noopener noreferrer" title="link to a pdf version of this section CV">download as pdf</a></span>
|
CV
|
||||||
|
-->
|
||||||
|
<section id="cv" class="section">
|
||||||
|
<header>
|
||||||
|
<!-- prettier-ignore -->
|
||||||
|
<h1 aria-label="curriculum vitae">
|
||||||
|
<span aria-hidden="true" class="pre">
|
||||||
|
<span class="fr en">
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</span>
|
||||||
|
</span>
|
||||||
|
</h1>
|
||||||
|
</header>
|
||||||
|
|
||||||
<p class="subtitle">
|
<div class="cv">
|
||||||
<span class="fr">Bonjour, je suis un développeur inventif, méthodique, et passionné par l'informatique. J'ai envie d'explorer toutes les technologies, et j'ai hâte de travailler avec vous :)</span>
|
<div class="cv_download">
|
||||||
<span class="en">Hello, I'm an inventive, methodical developer with a passion for IT. I'm keen to explore all kinds of technologies, and look forward to working with you. :)</span>
|
<p>
|
||||||
|
<span class="fr">télécharger </span>
|
||||||
|
<span class="en">download </span>
|
||||||
|
:
|
||||||
</p>
|
</p>
|
||||||
|
<a
|
||||||
|
href="docs/cvs/CV_Hugo_Lamy_Backend_Embedded_Developer_FR.pdf"
|
||||||
|
target="_blank"
|
||||||
|
rel="noopener noreferrer"
|
||||||
|
title="link to pdf CV version graphical FR"
|
||||||
|
>
|
||||||
|
<span class="fr">[Graphique FR]</span>
|
||||||
|
<span class="en">[Graphical FR]</span>
|
||||||
|
</a>
|
||||||
|
<a
|
||||||
|
href="docs/cvs/CV_Hugo_Lamy_Backend_Embedded_Developer_EN.pdf"
|
||||||
|
target="_blank"
|
||||||
|
rel="noopener noreferrer"
|
||||||
|
title="link to pdf CV version graphical EN"
|
||||||
|
>
|
||||||
|
<span class="fr">[Graphique EN]</span>
|
||||||
|
<span class="en">[Graphical EN]</span>
|
||||||
|
</a>
|
||||||
|
<a
|
||||||
|
href="docs/cvs/CV_Hugo_Lamy_Backend_Embedded_Developer_Ats_FR.pdf"
|
||||||
|
target="_blank"
|
||||||
|
rel="noopener noreferrer"
|
||||||
|
title="link to pdf CV version ats FR"
|
||||||
|
>
|
||||||
|
<span class="fr">[ATS FR]</span>
|
||||||
|
<span class="en">[ATS FR]</span>
|
||||||
|
</a>
|
||||||
|
<a
|
||||||
|
href="docs/cvs/CV_Hugo_Lamy_Backend_Embedded_Developer_Ats_EN.pdf"
|
||||||
|
target="_blank"
|
||||||
|
rel="noopener noreferrer"
|
||||||
|
title="link to pdf CV version ats EN"
|
||||||
|
>
|
||||||
|
<span class="fr">[ATS EN]</span>
|
||||||
|
<span class="en">[ATS EN]</span>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<h2>
|
||||||
|
<span class="fr">EXPÉRIENCES</span>
|
||||||
|
<span class="en">WORK EXPERIENCES</span>
|
||||||
|
</h2>
|
||||||
|
<div
|
||||||
|
class="banner banner_size_0 banner_pause"
|
||||||
|
aria-label="banner delimitation in ASCII art"
|
||||||
|
></div>
|
||||||
|
|
||||||
|
<h4>
|
||||||
|
<span class="fr">web full-stack</span>
|
||||||
|
<span class="en">web full-stack</span>
|
||||||
|
</h4>
|
||||||
|
<ul>
|
||||||
|
<li>
|
||||||
|
<span class="fr"
|
||||||
|
>BLOC-HOUSE: reprise du site d'une association d'artistes
|
||||||
|
(fullstack, php, javascript, html, css), 2023</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>BLOC-HOUSE: takeover of an artists' association website
|
||||||
|
(fullstack, php, javascript, html, css), 2023</span
|
||||||
|
>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<span class="fr"
|
||||||
|
>TRANSCENDENCE: chat en ligne avec gestions des comptes et
|
||||||
|
notifications (fullstack, node.js, nest.js, websocket, svelte,
|
||||||
|
PostgreSQL)</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>TRANSCENDENCE: online chat with account management and
|
||||||
|
notifications (fullstack, node.js, nest.js, websocket, svelte,
|
||||||
|
PostgreSQL)</span
|
||||||
|
>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<span class="fr"
|
||||||
|
>FIPF: plugin qui gère les paiements, les roles, corrige les
|
||||||
|
autres plugins et des actions front-end (fullstack, js, php, bdd),
|
||||||
|
2024</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>FIPF: plugin that manages payments, roles, corrects other plugins
|
||||||
|
and front-end actions (fullstack, js, php, bdd), 2024</span
|
||||||
|
>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<span class="fr"
|
||||||
|
>JIPF: utilise les API GoogleMaps pour afficher des données
|
||||||
|
dynamiques sur une carte avec des filtres, 2022</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>JIPF: uses GoogleMaps APIs to display dynamic data on a map, with
|
||||||
|
interactive filters</span
|
||||||
|
>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<span class="fr"
|
||||||
|
>KOSMOPOLIT: front-end, integration d'un site statique pour une
|
||||||
|
association de litterature, (html, css atomique), 2022</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>KOSMOPOLIT: front-end, integration of a static site for a
|
||||||
|
literature association, (html, atomic css), 2022</span
|
||||||
|
>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
<h4>
|
||||||
|
<span class="fr">devops</span>
|
||||||
|
<span class="en">devops</span>
|
||||||
|
</h4>
|
||||||
|
<ul>
|
||||||
|
<li>
|
||||||
|
<span class="fr"
|
||||||
|
>WEBSERV: création d'un serveur web non-bloquant en multiplexage,
|
||||||
|
capable de gérer des requetes http et envoyer du contenu (c++,
|
||||||
|
linux sockets)</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>WEBSERV: creation of a non-blocking multiplexing web server
|
||||||
|
capable of managing http requests and sending content (c++, linux
|
||||||
|
sockets)</span
|
||||||
|
>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<span class="fr"
|
||||||
|
>MINITALK: utiliser les signaux système de linux pour creer une
|
||||||
|
communication en code ascii entre deux processus</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>MINITALK: using linux system signals to create ascii code
|
||||||
|
communication between two processes</span
|
||||||
|
>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<span class="fr"
|
||||||
|
>INCEPTION: création de zéro d'ima-ges docker pour deployer
|
||||||
|
wordpress avec encription SSL (docker compose, mariaDB, NGINX,
|
||||||
|
Wordpress)</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>INCEPTION: creating docker images from scratch to deploy
|
||||||
|
wordpress with SSL encription (docker compose, mariaDB, NGINX,
|
||||||
|
Wordpress)</span
|
||||||
|
>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
<h4>
|
||||||
|
<span class="fr">game</span>
|
||||||
|
<span class="en">game</span>
|
||||||
|
</h4>
|
||||||
|
<ul>
|
||||||
|
<li>
|
||||||
|
<span class="fr"
|
||||||
|
>CUBE 3D: jeu à la premiere personne utilisant le raycasting pour
|
||||||
|
la 3d et les textures, et le clavier pour bouger (c,
|
||||||
|
trigonométrie, inputs)</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>CUBE 3D: first-person game using raycasting for 3d and textures,
|
||||||
|
and the keyboard for movement (c, trigonometry, inputs)</span
|
||||||
|
>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<span class="fr"
|
||||||
|
>FDF: modélisation spatiale de formes en courbes de niveau à
|
||||||
|
partir de cartes (c, trigonometrie, inputs)</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>FDF: spatial modelling of contour lines from maps with keyboard
|
||||||
|
control (c, trigonometrie, inputs)</span
|
||||||
|
>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
<h4>
|
||||||
|
<span class="fr">system</span>
|
||||||
|
<span class="en">system</span>
|
||||||
|
</h4>
|
||||||
|
<ul>
|
||||||
|
<li>
|
||||||
|
<span class="fr"
|
||||||
|
>MINISHELL: créer un shell capable de parser des prompts, exécuter
|
||||||
|
des programmes, et réagir aux signaux (c, bash, signals, fork,
|
||||||
|
pipe, readline)</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>MINISHELL: creating a shell capable of parsing prompts, executing
|
||||||
|
programs, and listening to signals (c, bash, signals, fork, pipe,
|
||||||
|
readline)</span
|
||||||
|
>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<span class="fr"
|
||||||
|
>CONTAINERS: recoder 3 conteneurs c++ avec les iterateurs,
|
||||||
|
surcharges, et templates : map, vector, stack</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>CONTAINERS: recoding c++ containers with iterators, overloads and
|
||||||
|
templates : map, vector, stack</span
|
||||||
|
>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<span class="fr"
|
||||||
|
>PUSHSWAP: algorithmes de tris avec deux piles et des mouvements
|
||||||
|
limités aux extrémités des piles (c)</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>PUSHSWAP: sorting algorithms with two stacks and limited movement
|
||||||
|
at the ends of the stacks (c)</span
|
||||||
|
>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
<h2>
|
<h2>
|
||||||
<span class="fr">COMPÉTENCES</span>
|
<span class="fr">COMPÉTENCES</span>
|
||||||
<span class="en">SKILLS</span>
|
<span class="en">SKILLS</span>
|
||||||
</h2>
|
</h2>
|
||||||
<div class="banner banner_size_0 banner_pause" aria-label="banner delimitation in ASCII art"></div>
|
<div
|
||||||
|
class="banner banner_size_0 banner_pause"
|
||||||
|
aria-label="banner delimitation in ASCII art"
|
||||||
|
></div>
|
||||||
|
|
||||||
<h4>
|
<h4>
|
||||||
<span class="fr">hard skills</span>
|
<span class="fr">hard skills</span>
|
||||||
@@ -127,16 +393,32 @@
|
|||||||
</h4>
|
</h4>
|
||||||
<ul>
|
<ul>
|
||||||
<li>
|
<li>
|
||||||
<span class="fr">Langages : C, C++, bash, JavaScript, PHP, CSS, HTML</span>
|
<span class="fr"
|
||||||
<span class="en">Languages : C, C++, bash, JavaScript, PHP, CSS, HTML</span>
|
>Langages : C, C++, bash, JavaScript, PHP, CSS, HTML</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>Languages : C, C++, bash, JavaScript, PHP, CSS, HTML</span
|
||||||
|
>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<span class="fr">Technologies : Node.js, Git, Gitaction, Docker, Wordpress, Nginx, MariaDB, Nest.js, Svelte, WebSocket, Express, npm, react</span>
|
<span class="fr"
|
||||||
<span class="en">Technologies : Node.js, Git, Gitaction, Docker, Wordpress, Nginx, MariaDB, Nest.js, Svelte, WebSocket, Express, npm, react</span>
|
>Technologies : Node.js, Git, Gitaction, Docker, Wordpress, Nginx,
|
||||||
|
MariaDB, Nest.js, Svelte, WebSocket, Express, npm, react</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>Technologies : Node.js, Git, Gitaction, Docker, Wordpress, Nginx,
|
||||||
|
MariaDB, Nest.js, Svelte, WebSocket, Express, npm, react</span
|
||||||
|
>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<span class="fr">Plus : emails, sending emails, receiving emails, deleting emails (the it crowd S01E01)</span>
|
<span class="fr"
|
||||||
<span class="en">Plus : emails, sending emails, receiving emails, deleting emails (the it crowd S01E01)</span>
|
>Plus : emails, sending emails, receiving emails, deleting emails
|
||||||
|
(the it crowd S01E01)</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>Plus : emails, sending emails, receiving emails, deleting emails
|
||||||
|
(the it crowd S01E01)</span
|
||||||
|
>
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
<h4>
|
<h4>
|
||||||
@@ -162,99 +444,14 @@
|
|||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
<h2>
|
|
||||||
<span class="fr">EXPÉRIENCES</span>
|
|
||||||
<span class="en">WORK EXPERIENCES</span>
|
|
||||||
</h2>
|
|
||||||
<div class="banner banner_size_0 banner_pause" aria-label="banner delimitation in ASCII art"></div>
|
|
||||||
|
|
||||||
<h4>
|
|
||||||
<span class="fr">web full-stack</span>
|
|
||||||
<span class="en">web full-stack</span>
|
|
||||||
</h4>
|
|
||||||
<ul>
|
|
||||||
<li>
|
|
||||||
<span class="fr">BLOC-HOUSE: reprise du site d'une association d'artistes (fullstack, php, javascript, html, css), 2023</span>
|
|
||||||
<span class="en">BLOC-HOUSE: takeover of an artists' association website (fullstack, php, javascript, html, css), 2023</span>
|
|
||||||
</li>
|
|
||||||
<li>
|
|
||||||
<span class="fr">TRANSCENDENCE: chat en ligne avec gestions des comptes et notifications (fullstack, node.js, nest.js, websocket, svelte, PostgreSQL)</span>
|
|
||||||
<span class="en">TRANSCENDENCE: online chat with account management and notifications (fullstack, node.js, nest.js, websocket, svelte, PostgreSQL)</span>
|
|
||||||
</li>
|
|
||||||
<li>
|
|
||||||
<span class="fr">FIPF: plugin qui gère les paiements, les roles, corrige les autres plugins et des actions front-end (fullstack, js, php, bdd), 2024</span>
|
|
||||||
<span class="en">FIPF: plugin that manages payments, roles, corrects other plugins and front-end actions (fullstack, js, php, bdd), 2024</span>
|
|
||||||
</li>
|
|
||||||
<li>
|
|
||||||
<span class="fr">JIPF: utilise les API GoogleMaps pour afficher des données dynamiques sur une carte avec des filtres, 2022</span>
|
|
||||||
<span class="en">JIPF: uses GoogleMaps APIs to display dynamic data on a map, with interactive filters</span>
|
|
||||||
</li>
|
|
||||||
<li>
|
|
||||||
<span class="fr">KOSMOPOLIT: front-end, integration d'un site statique pour une association de litterature, (html, css atomique), 2022</span>
|
|
||||||
<span class="en">KOSMOPOLIT: front-end, integration of a static site for a literature association, (html, atomic css), 2022</span>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
|
|
||||||
<h4>
|
|
||||||
<span class="fr">devops</span>
|
|
||||||
<span class="en">devops</span>
|
|
||||||
</h4>
|
|
||||||
<ul>
|
|
||||||
<li>
|
|
||||||
<span class="fr">WEBSERV: création d'un serveur web non-bloquant en multiplexage, capable de gérer des requetes http et envoyer du contenu (c++, linux sockets)</span>
|
|
||||||
<span class="en">WEBSERV: creation of a non-blocking multiplexing web server capable of managing http requests and sending content (c++, linux sockets)</span>
|
|
||||||
</li>
|
|
||||||
<li>
|
|
||||||
<span class="fr">MINITALK: utiliser les signaux système de linux pour creer une communication en code ascii entre deux processus</span>
|
|
||||||
<span class="en">MINITALK: using linux system signals to create ascii code communication between two processes</span>
|
|
||||||
</li>
|
|
||||||
<li>
|
|
||||||
<span class="fr">INCEPTION: création de zéro d'ima-ges docker pour deployer wordpress avec encription SSL (docker compose, mariaDB, NGINX, Wordpress)</span>
|
|
||||||
<span class="en">INCEPTION: creating docker images from scratch to deploy wordpress with SSL encription (docker compose, mariaDB, NGINX, Wordpress)</span>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
|
|
||||||
<h4>
|
|
||||||
<span class="fr">game</span>
|
|
||||||
<span class="en">game</span>
|
|
||||||
</h4>
|
|
||||||
<ul>
|
|
||||||
<li>
|
|
||||||
<span class="fr">CUBE 3D: jeu à la premiere personne utilisant le raycasting pour la 3d et les textures, et le clavier pour bouger (c, trigonometrie, inputs)</span>
|
|
||||||
<span class="en">CUBE 3D: first-person game using raycasting for 3d and textures, and the keyboard for movement (c, trigonometrie, inputs)</span>
|
|
||||||
</li>
|
|
||||||
<li>
|
|
||||||
<span class="fr">FDF: modélisation spatiale de formes en courbes de niveau à partir de cartes (c, trigonometrie, inputs)</span>
|
|
||||||
<span class="en">FDF: spatial modelling of contour lines from maps with keyboard control (c, trigonometrie, inputs)</span>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
|
|
||||||
<h4>
|
|
||||||
<span class="fr">system</span>
|
|
||||||
<span class="en">system</span>
|
|
||||||
</h4>
|
|
||||||
<ul>
|
|
||||||
<li>
|
|
||||||
<span class="fr">MINISHELL: créer un shell capable de parser des prompts, exécuter des programmes, et réagir aux signaux (c, bash, signals, fork, pipe, readline)</span>
|
|
||||||
<span class="en">MINISHELL: creating a shell capable of parsing prompts, executing pro-grams, and listening to signals (c, bash, signals, fork, pipe, readline)</span>
|
|
||||||
</li>
|
|
||||||
<li>
|
|
||||||
<span class="fr">CONTAINERS: recoder 3 conteneurs c++ avec les iterateurs, surcharges, et templates : map, vector, stack</span>
|
|
||||||
<span class="en">CONTAINERS: recoding c++ containers with iterators, overloads and templates : map, vector, stack</span>
|
|
||||||
</li>
|
|
||||||
<li>
|
|
||||||
<span class="fr">PUSHSWAP: algorithmes de tris avec deux piles et des mouvements limités aux extrémités des piles (c)</span>
|
|
||||||
<span class="en">PUSHSWAP: sorting algorithms with two stacks and limited movement at the ends of the stacks (c)</span>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
|
|
||||||
|
|
||||||
<h2>
|
<h2>
|
||||||
<span class="fr">FORMATIONS</span>
|
<span class="fr">FORMATIONS</span>
|
||||||
<span class="en">EDUCATIONS</span>
|
<span class="en">EDUCATIONS</span>
|
||||||
</h2>
|
</h2>
|
||||||
<div class="banner banner_size_0 banner_pause" aria-label="banner delimitation in ASCII art"></div>
|
<div
|
||||||
|
class="banner banner_size_0 banner_pause"
|
||||||
|
aria-label="banner delimitation in ASCII art"
|
||||||
|
></div>
|
||||||
|
|
||||||
<h4>
|
<h4>
|
||||||
<span class="fr">informatique</span>
|
<span class="fr">informatique</span>
|
||||||
@@ -262,12 +459,24 @@
|
|||||||
</h4>
|
</h4>
|
||||||
<ul>
|
<ul>
|
||||||
<li>
|
<li>
|
||||||
<span class="fr">École 42, Paris, 2021-2022, tronc commun - niveau 10 (C, C++, système, algorithmie, réseaux)</span>
|
<span class="fr"
|
||||||
<span class="en">42 school, Paris, 2021-2022, common core - level 10 (C, C++, system, algorithms, networks)</span>
|
>École 42, Paris, 2021-2022, tronc commun - niveau 10 (C, C++,
|
||||||
|
système, algorithmie, réseaux)</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>42 school, Paris, 2021-2022, common core - level 10 (C, C++,
|
||||||
|
system, algorithms, networks)</span
|
||||||
|
>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<span class="fr">SIMPLON, développeur full-stack JavaScript, 2018 (Javascript, Node.js, React.js, HTML, CSS)</span>
|
<span class="fr"
|
||||||
<span class="en">SIMPLON, developer full-stack JavaScript, 2018 (Javascript, Node.js, React.js, HTML, CSS)</span>
|
>SIMPLON, développeur full-stack JavaScript, 2018 (Javascript,
|
||||||
|
Node.js, React.js, HTML, CSS)</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>SIMPLON, developer full-stack JavaScript, 2018 (Javascript,
|
||||||
|
Node.js, React.js, HTML, CSS)</span
|
||||||
|
>
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
<h4>
|
<h4>
|
||||||
@@ -276,21 +485,35 @@
|
|||||||
</h4>
|
</h4>
|
||||||
<ul>
|
<ul>
|
||||||
<li>
|
<li>
|
||||||
<span class="fr">Master 1, ENSAPM, ESA, ENSAV, île-de-france, France, 2008-2014</span>
|
<span class="fr"
|
||||||
<span class="en">Master 1, ENSAPM, ESA, ENSAV, île-de-france, France, 2008-2014</span>
|
>Master 1, ENSAPM, ESA, ENSAV, île-de-france, France,
|
||||||
|
2008-2014</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>Master 1, ENSAPM, ESA, ENSAV, île-de-france, France,
|
||||||
|
2008-2014</span
|
||||||
|
>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<span class="fr">3 stages : PERSPECTIVA (Houston, Texas, 2009, 3 mois), AS (Paris, 2012, 6 mois), JC QUINTON (Paris 2014, 6 mois)</span>
|
<span class="fr"
|
||||||
<span class="en">3 internships : PERSPECTIVA (Houston, Texas, 2009, 3 months), AS (Paris, 2012, 6 months), JC QUINTON (Paris 2014, 6 months)</span>
|
>3 stages : PERSPECTIVA (Houston, Texas, 2009, 3 mois), AS (Paris,
|
||||||
|
2012, 6 mois), JC QUINTON (Paris 2014, 6 mois)</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>3 internships : PERSPECTIVA (Houston, Texas, 2009, 3 months), AS
|
||||||
|
(Paris, 2012, 6 months), JC QUINTON (Paris 2014, 6 months)</span
|
||||||
|
>
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
<h2>
|
<h2>
|
||||||
<span class="fr">PERSONNEL</span>
|
<span class="fr">PERSONNEL</span>
|
||||||
<span class="en">PERSONAL</span>
|
<span class="en">PERSONAL</span>
|
||||||
</h2>
|
</h2>
|
||||||
<div class="banner banner_size_0 banner_pause" aria-label="banner delimitation in ASCII art"></div>
|
<div
|
||||||
|
class="banner banner_size_0 banner_pause"
|
||||||
|
aria-label="banner delimitation in ASCII art"
|
||||||
|
></div>
|
||||||
|
|
||||||
<h4>
|
<h4>
|
||||||
<span class="fr">engagement associatif</span>
|
<span class="fr">engagement associatif</span>
|
||||||
@@ -298,20 +521,44 @@
|
|||||||
</h4>
|
</h4>
|
||||||
<ul>
|
<ul>
|
||||||
<li>
|
<li>
|
||||||
<span class="fr">Vulgarisation et recherche contraception testiculaire, ZEROMILLIONS, Paris, France, 2021-2024</span>
|
<span class="fr"
|
||||||
<span class="en">Popularisation and research into testicular contraception, ZEROMILLIONS, Paris, France, 2021-2024</span>
|
>Vulgarisation et recherche contraception testiculaire,
|
||||||
|
ZEROMILLIONS, Paris, France, 2021-2024</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>Popularisation and research into testicular contraception,
|
||||||
|
ZEROMILLIONS, Paris, France, 2021-2024</span
|
||||||
|
>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<span class="fr">Aide au logement, travail, administratif, et projets de vie de personnes précaires, 2018-2024</span>
|
<span class="fr"
|
||||||
<span class="en">Help with housing, work, administration and life projects for people on the margins of society, 2018-2024</span>
|
>Aide au logement, travail, administratif, et projets de vie de
|
||||||
|
personnes précaires, 2018-2024</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>Help with housing, work, administration and life projects for
|
||||||
|
people on the margins of society, 2018-2024</span
|
||||||
|
>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<span class="fr">Distribution de nourriture, MIGRANTS-WILSON & SECOURS POPULAIRE, 2020-2022</span>
|
<span class="fr"
|
||||||
<span class="en">Food distribution, MIGRANTS-WILSON & SECOURS POPULAIRE, 2020-2022</span>
|
>Distribution de nourriture, MIGRANTS-WILSON & SECOURS POPULAIRE,
|
||||||
|
2020-2022</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>Food distribution, MIGRANTS-WILSON & SECOURS POPULAIRE,
|
||||||
|
2020-2022</span
|
||||||
|
>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<span class="fr">Cogestion des bénévoles d'un camp de réfugiés, UTOPIA 56, Grande-Synthe, France, 2016</span>
|
<span class="fr"
|
||||||
<span class="en">Co-management of volunteers in a refugee camp, UTOPIA 56, Grande-Synthe, France, 2016</span>
|
>Cogestion des bénévoles d'un camp de réfugiés, UTOPIA 56,
|
||||||
|
Grande-Synthe, France, 2016</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>Co-management of volunteers in a refugee camp, UTOPIA 56,
|
||||||
|
Grande-Synthe, France, 2016</span
|
||||||
|
>
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
<h4>
|
<h4>
|
||||||
@@ -340,26 +587,21 @@
|
|||||||
<span class="en">politic</span>
|
<span class="en">politic</span>
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
|
</div>
|
||||||
|
|
||||||
</details>
|
<div class="mouse"><div class="frames mouse_3 pre"></div></div>
|
||||||
|
<div
|
||||||
<div class="mouse"><div class="frames mouse_1 pre"></div></div>
|
class="banner banner_size_2 banner_reverse banner_speed_40 grid_full_width margin_bottom_small"
|
||||||
<div class="banner banner_size_3 banner_speed_30 grid_full_width margin_bottom_small" aria-label="banner delimitation in ASCII art"></div>
|
aria-label="banner delimitation in ASCII art"
|
||||||
|
></div>
|
||||||
</section>
|
</section>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<!--
|
<!--
|
||||||
PROJECTS
|
PROJECTS
|
||||||
-->
|
-->
|
||||||
<section id="projects" class="section">
|
<section id="projects" class="section">
|
||||||
<div class="mouse"><div class="frames mouse_3 pre"></div></div>
|
|
||||||
|
|
||||||
<header>
|
<header>
|
||||||
|
<!-- prettier-ignore -->
|
||||||
<h1 aria-label="projets">
|
<h1 aria-label="projets">
|
||||||
<span aria-hidden="true" class="pre">
|
<span aria-hidden="true" class="pre">
|
||||||
<span class="fr">
|
<span class="fr">
|
||||||
@@ -385,7 +627,12 @@
|
|||||||
<span class="fr">code-sources de tous les projets : </span>
|
<span class="fr">code-sources de tous les projets : </span>
|
||||||
<span class="en">source code for all projects : </span>
|
<span class="en">source code for all projects : </span>
|
||||||
</p>
|
</p>
|
||||||
<a href="https://bitbucket.org/hugogogo" target="_blank" rel="noopener noreferrer" title="link to git repositories on bitbucket"></a>
|
<a
|
||||||
|
href="https://gitea.hugulumu.com/"
|
||||||
|
target="_blank"
|
||||||
|
rel="noopener noreferrer"
|
||||||
|
title="link to git repositories"
|
||||||
|
></a>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<h2 class="margin_bottom_big">
|
<h2 class="margin_bottom_big">
|
||||||
@@ -395,84 +642,138 @@
|
|||||||
|
|
||||||
<div class="projects_grid">
|
<div class="projects_grid">
|
||||||
<figure class="project">
|
<figure class="project">
|
||||||
<a href="https://bitbucket.org/hugogogo/int_04_fdf" target="_blank" rel="noopener noreferrer" title="link to the source code on bitbucket">
|
<a
|
||||||
|
href="https://gitea.hugulumu.com/42/42_INT_04_fdf"
|
||||||
|
target="_blank"
|
||||||
|
rel="noopener noreferrer"
|
||||||
|
title="link to the source code"
|
||||||
|
>
|
||||||
<img src="./docs/projects/fdf_pyramide_loop_square_2_light.gif" />
|
<img src="./docs/projects/fdf_pyramide_loop_square_2_light.gif" />
|
||||||
</a>
|
</a>
|
||||||
<figcaption>
|
<figcaption>
|
||||||
<p>
|
<p>
|
||||||
<span class="fr">programme qui creer une representation 3D filaire d'une carte avec des points a differentes altitudes</span>
|
<span class="fr"
|
||||||
<span class="en">program that creates a 3D wireframe representation of a map with points at different altitudes</span>
|
>programme qui creer une representation 3D filaire d'une carte
|
||||||
|
avec des points a differentes altitudes</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>program that creates a 3D wireframe representation of a map
|
||||||
|
with points at different altitudes</span
|
||||||
|
>
|
||||||
</p>
|
</p>
|
||||||
<a href="https://bitbucket.org/hugogogo/int_04_fdf" target="_blank" rel="noopener noreferrer" title="link to the source code on bitbucket"></a>
|
<a
|
||||||
|
href="https://gitea.hugulumu.com/42/42_INT_04_fdf"
|
||||||
|
target="_blank"
|
||||||
|
rel="noopener noreferrer"
|
||||||
|
title="link to the source code"
|
||||||
|
></a>
|
||||||
</figcaption>
|
</figcaption>
|
||||||
</figure>
|
</figure>
|
||||||
|
|
||||||
<figure class="project">
|
<figure class="project">
|
||||||
<a href="https://bitbucket.org/hugogogo/int_10_cube3d" target="_blank" rel="noopener noreferrer" title="link to the source code on bitbucket">
|
<a
|
||||||
|
href="https://gitea.hugulumu.com/42/42_INT_10_cube3d"
|
||||||
|
target="_blank"
|
||||||
|
rel="noopener noreferrer"
|
||||||
|
title="link to the source code"
|
||||||
|
>
|
||||||
<img src="./docs/projects/cube3d_tour_with_map_square.gif" />
|
<img src="./docs/projects/cube3d_tour_with_map_square.gif" />
|
||||||
</a>
|
</a>
|
||||||
<figcaption>
|
<figcaption>
|
||||||
<p>
|
<p>
|
||||||
<span class="fr">mini jeu video utilisant le raycasting pour creer une impression de deplacement dans un environnement 3D</span>
|
<span class="fr"
|
||||||
<span class="en">mini video game using raycasting to create the impression of movement in a 3D environment</span>
|
>mini jeu video utilisant le raycasting pour creer une
|
||||||
|
impression de deplacement dans un environnement 3D</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>mini video game using raycasting to create the impression of
|
||||||
|
movement in a 3D environment</span
|
||||||
|
>
|
||||||
</p>
|
</p>
|
||||||
<a href="https://bitbucket.org/hugogogo/int_10_cube3d" target="_blank" rel="noopener noreferrer" title="link to the source code on bitbucket"></a>
|
<a
|
||||||
|
href="https://gitea.hugulumu.com/42/42_INT_10_cube3d"
|
||||||
|
target="_blank"
|
||||||
|
rel="noopener noreferrer"
|
||||||
|
title="link to the source code"
|
||||||
|
></a>
|
||||||
</figcaption>
|
</figcaption>
|
||||||
</figure>
|
</figure>
|
||||||
|
|
||||||
<figure class="project">
|
<figure class="project">
|
||||||
<a href="https://bitbucket.org/hugogogo/2023_website_jipf" target="_blank" rel="noopener noreferrer" title="link to the source code on bitbucket">
|
<a
|
||||||
|
href="https://gitea.hugulumu.com/pro/2023_WEBSITE_jipf"
|
||||||
|
target="_blank"
|
||||||
|
rel="noopener noreferrer"
|
||||||
|
title="link to the source code"
|
||||||
|
>
|
||||||
<img src="./docs/projects/ljdp_map_clusters_square_light.gif" />
|
<img src="./docs/projects/ljdp_map_clusters_square_light.gif" />
|
||||||
</a>
|
</a>
|
||||||
<figcaption>
|
<figcaption>
|
||||||
<p>
|
<p>
|
||||||
<span class="fr">plugin wordpress representant des evenements sur une carte avec des marqueurs et des filtres de tris</span>
|
<span class="fr"
|
||||||
<span class="en">wordpress plugin showing events on a map with markers and sorting filters</span>
|
>plugin wordpress representant des evenements sur une carte avec
|
||||||
|
des marqueurs et des filtres de tris</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>wordpress plugin showing events on a map with markers and
|
||||||
|
sorting filters</span
|
||||||
|
>
|
||||||
</p>
|
</p>
|
||||||
<a href="https://bitbucket.org/hugogogo/2023_website_jipf" target="_blank" rel="noopener noreferrer" title="link to the source code on bitbucket"></a>
|
<a
|
||||||
|
href="https://gitea.hugulumu.com/pro/2023_WEBSITE_jipf"
|
||||||
|
target="_blank"
|
||||||
|
rel="noopener noreferrer"
|
||||||
|
title="link to the source code"
|
||||||
|
></a>
|
||||||
</figcaption>
|
</figcaption>
|
||||||
</figure>
|
</figure>
|
||||||
|
|
||||||
<figure class="project">
|
<figure class="project">
|
||||||
<a href="https://bitbucket.org/hugogogo/2022_website_kosmopolit" target="_blank" rel="noopener noreferrer" title="link to the source code on bitbucket">
|
<a
|
||||||
|
href="https://gitea.hugulumu.com/pro/2022_WEBSITE_kosmopolit"
|
||||||
|
target="_blank"
|
||||||
|
rel="noopener noreferrer"
|
||||||
|
title="link to the source code"
|
||||||
|
>
|
||||||
<img src="./docs/projects/kosmopolit_square.gif" />
|
<img src="./docs/projects/kosmopolit_square.gif" />
|
||||||
</a>
|
</a>
|
||||||
<figcaption>
|
<figcaption>
|
||||||
<p>
|
<p>
|
||||||
<span class="fr">site internet statique utilisant une structure uniquement en html et css</span>
|
<span class="fr"
|
||||||
<span class="en">static website using a structure based solely on html and css</span>
|
>site internet statique utilisant une structure uniquement en
|
||||||
|
html et css</span
|
||||||
|
>
|
||||||
|
<span class="en"
|
||||||
|
>static website using a structure based solely on html and
|
||||||
|
css</span
|
||||||
|
>
|
||||||
</p>
|
</p>
|
||||||
<a href="https://bitbucket.org/hugogogo/2022_website_kosmopolit" target="_blank" rel="noopener noreferrer" title="link to the source code on bitbucket"></a>
|
<a
|
||||||
|
href="https://gitea.hugulumu.com/pro/2022_WEBSITE_kosmopolit"
|
||||||
|
target="_blank"
|
||||||
|
rel="noopener noreferrer"
|
||||||
|
title="link to the source code"
|
||||||
|
></a>
|
||||||
</figcaption>
|
</figcaption>
|
||||||
</figure>
|
</figure>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="mouse"><div class="frames mouse_2 pre"></div></div>
|
<div class="mouse"><div class="frames mouse_2 pre"></div></div>
|
||||||
<div class="banner banner_size_3 banner_speed_20 banner_reverse grid_full_width" aria-label="banner delimitation in ASCII art"></div>
|
<div
|
||||||
|
class="banner banner_size_3 banner_speed_20 banner_reverse grid_full_width"
|
||||||
|
aria-label="banner delimitation in ASCII art"
|
||||||
|
></div>
|
||||||
</section>
|
</section>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<!--
|
<!--
|
||||||
INFOS
|
INFOS
|
||||||
-->
|
-->
|
||||||
<section id="infos" class="footer section">
|
<section id="infos" class="footer section">
|
||||||
|
|
||||||
<article>
|
<article>
|
||||||
<p>hugogogo@protonmail.com</p>
|
<a href="mailto:hugogogo@protonmail.com">hugogogo@protonmail.com</a>
|
||||||
</article>
|
</article>
|
||||||
|
|
||||||
<div class="mouse"><div class="frames mouse_4 pre"></div></div>
|
<div class="mouse"><div class="frames mouse_4 pre"></div></div>
|
||||||
|
|
||||||
</section>
|
</section>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|||||||
@@ -1,60 +1,38 @@
|
|||||||
.cv {
|
#cv {
|
||||||
width: auto;
|
header {
|
||||||
max-width: 900px;
|
height: 300px;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.cv {
|
.cv {
|
||||||
display: flex;
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
text-align: left;
|
text-align: left;
|
||||||
}
|
width: auto;
|
||||||
.cv summary {
|
max-width: 900px;
|
||||||
position: relative;
|
|
||||||
list-style-position: outside;
|
|
||||||
list-style-type: "▸ ";
|
|
||||||
font-size: 1.8rem;
|
|
||||||
margin: auto;
|
|
||||||
width: fit-content;
|
|
||||||
}
|
|
||||||
.cv summary .open {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
.cv summary .close {
|
|
||||||
display: inline;
|
|
||||||
}
|
|
||||||
|
|
||||||
.cv .cv_download {
|
> *:last-child {
|
||||||
display: inline-block;
|
|
||||||
width: 100%;
|
|
||||||
margin-top: 30px;
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.cv[open] summary {
|
|
||||||
list-style-type: "▾ ";
|
|
||||||
}
|
|
||||||
.cv[open] summary .open {
|
|
||||||
display: inline;
|
|
||||||
}
|
|
||||||
.cv[open] summary .close {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.cv > *:last-child {
|
|
||||||
margin-bottom: 100px;
|
margin-bottom: 100px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.cv .banner {
|
.cv_download {
|
||||||
margin: 0px 0px 50px;
|
display: flex;
|
||||||
/*
|
flex-wrap: wrap;
|
||||||
margin: 50px 50px;
|
gap: 10px;
|
||||||
width: calc(100% - 100px);
|
margin-top: 30px;
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
.cv h2 {
|
|
||||||
|
.banner {
|
||||||
|
margin: 0px 0px 50px;
|
||||||
|
}
|
||||||
|
|
||||||
|
h2 {
|
||||||
margin-top: 100px;
|
margin-top: 100px;
|
||||||
}
|
}
|
||||||
.cv ul {
|
|
||||||
|
ul {
|
||||||
border: 1px dashed black;
|
border: 1px dashed black;
|
||||||
padding: 20px;
|
padding: 20px;
|
||||||
padding-left: 40px;
|
padding-left: 40px;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|||||||
@@ -4,15 +4,16 @@
|
|||||||
/*
|
/*
|
||||||
* WIP : trying to find a solution to have both qualities :
|
* WIP : trying to find a solution to have both qualities :
|
||||||
* - elements are spread across the page vertically ('hugo lamy developpeur' is not compacted on top)
|
* - elements are spread across the page vertically ('hugo lamy developpeur' is not compacted on top)
|
||||||
* - the details element 'voir le cv' dont jump when we unroll it
|
* - the details element 'voir le cv' don't jump when we unroll it
|
||||||
*
|
*
|
||||||
grid-template-rows: 1fr auto 1fr;
|
grid-template-rows: 1fr auto 1fr;
|
||||||
grid-template-rows: auto auto 1fr;
|
grid-template-rows: auto auto 1fr;
|
||||||
*/
|
*/
|
||||||
grid-template-rows: 50vh auto 1fr;
|
grid-template-rows: 50vh 1fr;
|
||||||
}
|
}
|
||||||
#hero .subtitle {
|
#hero .subtitle {
|
||||||
text-align: center;
|
text-align: center;
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
max-width: 700px;
|
max-width: 700px;
|
||||||
|
margin: 0px auto;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,50 +3,57 @@ input#language {
|
|||||||
}
|
}
|
||||||
label#language_label {
|
label#language_label {
|
||||||
position: fixed;
|
position: fixed;
|
||||||
position: absolute;
|
|
||||||
top: 20px;
|
top: 20px;
|
||||||
right: 20px;
|
right: 20px;
|
||||||
padding: 10px;
|
padding: 10px;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
z-index: 1;
|
z-index: 1;
|
||||||
}
|
|
||||||
label#language_label .flag {
|
.flag {
|
||||||
width: 20px;
|
width: 20px;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* FR
|
* SWITCH FLAG
|
||||||
*/
|
*/
|
||||||
input#language:not(:checked) + label #fr {
|
#language {
|
||||||
display: inline;
|
&:not(:checked) + #language_label {
|
||||||
}
|
#fr {
|
||||||
input#language:checked + label #fr {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
input#language:not(:checked) ~ * span.fr {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
input#language:checked ~ * span.fr {
|
|
||||||
display: inline;
|
display: inline;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#en {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&:checked + #language_label {
|
||||||
|
#fr {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
#en {
|
||||||
|
display: inline;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* EN
|
* SWITCH LANGUAGE
|
||||||
*/
|
*/
|
||||||
input#language:not(:checked) + label #en {
|
|
||||||
display: none;
|
#language {
|
||||||
}
|
~ * .fr,
|
||||||
input#language:checked + label #en {
|
~ * .en {
|
||||||
display: inline;
|
|
||||||
}
|
|
||||||
input#language:not(:checked) ~ * span.en {
|
|
||||||
display: inline;
|
|
||||||
}
|
|
||||||
input#language:checked ~ * span.en {
|
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
&:not(:checked) ~ * .en {
|
||||||
|
display: inline;
|
||||||
|
}
|
||||||
|
|
||||||
|
&:checked ~ * .fr {
|
||||||
|
display: inline;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user