Primo test stilistico vagamente serio

main-old
Antonio De Lucreziis 4 years ago
parent 26268329d9
commit 6c36b803e9

@ -1,485 +1,308 @@
/* TODO: Don't use CDN and serve as assets */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Share:wght@700&family=Ubuntu+Mono&family=Ubuntu:wght@300;700&display=swap');
/* @import url('https://fonts.googleapis.com/css2?family=Sen&family=Work+Sans:wght@700&display=swap'); */
:root { :root {
--font-title: 'Share', cursive; --bg: #f0f0f0;
--font-text: 'Ubuntu', sans-serif; --fg: #333;
--font-mono: 'Ubuntu Mono', monospace;
}
* {
box-sizing: border-box;
}
html, /* --bg-dark: #e0e0d6;
body { --bg-darker: #d6d6cc; */
position: relative;
margin: 0;
min-height: 100%;
width: 100vw; --bg-dark: hsl(220, 5%, 93%);
overflow-x: hidden; --bg-darker: hsl(220, 5%, 90%);
font-family: var(--font-text); --accent-1: #278542;
font-weight: 300; --accent-1-fg: #154d24;
font-size: 17px;
line-height: 1.25;
}
html { --font-sf: 'Inter', sans-serif;
background: white; --font-weight-light: 300;
--font-weight-normal: 400;
--font-weight-medium: 500;
--font-weight-bold: 700;
height: 100%; --shadow-1: 0 0 16px 0 #00000018;
min-height: 100%;
} }
body { * {
margin: 0 auto; box-sizing: border-box;
padding-bottom: 5rem;
max-width: 850px;
text-align: justify;
background: white;
} }
/* Typography */ html, body {
h1, h2, h3, h4 {
margin: 0; margin: 0;
width: 100%;
font-family: var(--font-title); height: fit-content;
font-weight: 700;
}
p {
margin: 0.75rem 0;
}
p:last-child {
margin-bottom: 0;
}
/* Elements */
nav {
margin-bottom: 1rem;
display: flex;
flex-wrap: wrap;
border: 4px solid;
border-top: none;
gap: 2px;
/* border-bottom: 1rem solid black; */
} }
.nav-item { body {
flex-grow: 1;
display: flex; display: flex;
flex-direction: column;
align-items: center; align-items: center;
justify-content: center;
height: 2.5rem;
padding: 0 0.75rem; background: var(--bg);
margin: -2px; color: var(--fg);
font-size: 130%; font-family: var(--font-sf);
font-weight: bold; font-size: 17px;
font-weight: var(--font-weight-normal);
border: 2px solid black; position: relative;
} }
.nav-dropdown { .main {
flex-grow: 1; max-width: 70ch;
margin: -2px; margin: 0 auto 8rem;
max-width: 100%;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
position: relative;
z-index: 1; gap: 3rem;
} }
.nav-dropdown .label { nav {
display: flex; margin: 1rem 0;
align-items: center;
justify-content: center;
width: 100%;
height: 2.5rem;
padding: 0 0.75rem;
font-size: 130%; display: grid;
font-weight: bold; grid-template-columns: auto 1fr;
gap: 1rem;
border: 2px solid black; align-items: center;
} font-weight: var(--font-weight-medium);
.nav-dropdown .label .icons8 { color: var(--accent-1-fg);
width: 16px;
height: 16px;
margin-left: 0.5rem; z-index: 0;
transform: translate(0, 0.1rem);
} }
.nav-dropdown .dropdown { /* Tutti i link dentro la navbar sono speciali e non sembrano link */
position: absolute; nav a {
top: 100%;
width: 100%;
/* margin-bottom: 0.5rem; */
display: flex; display: flex;
flex-direction: column; width: 100%;
height: 100%;
gap: 2px;
border: 2px solid black;
background: white;
}
.nav-dropdown:not(:hover) .dropdown { align-items: center;
display: none; justify-content: center;
}
nav a {
text-decoration: none; text-decoration: none;
color: inherit;
} }
section { nav a:hover {
border: 4px solid; color: var(--accent-1-fg);
text-decoration: none;
padding: 1rem;
margin-bottom: 1rem;
} }
header { nav .nav-logo {
/* height: 3.5rem; */
display: flex; display: flex;
width: 100%; align-items: center;
justify-content: center; justify-content: center;
padding: 0.5rem;
margin: 2.5rem 0;
}
header .logo {
flex-grow: 1;
margin-right: 1rem; background: var(--bg-dark);
object-fit: contain; border-radius: 4px;
object-position: right; border: 1px solid #dadada;
box-shadow: var(--shadow-1);
} }
header .title { nav .nav-main {
flex-grow: 1; display: grid;
grid-template-columns: repeat(5, 1fr) 2fr 1fr;
display: flex;
flex-direction: column;
justify-content: space-around;
}
header .title h1 { background: var(--bg-dark);
font-size: 56px; border-radius: 4px;
display: inline-block; border: 1px solid #dadada;
transform: translate(-0.125rem); box-shadow: var(--shadow-1);
}
.service-list {
display: flex;
flex-wrap: wrap;
gap: 0.5rem; z-index: -1;
} }
.service { nav .nav-main a {
flex: 1 1 calc(50% - 1rem); padding: 0.75rem 1rem;
min-width: 300px;
padding: 1rem 0.75rem;
/* Brutal */
border: 2px solid black;
} }
.user-list { nav .nav-main .nav-item {
display: flex; display: flex;
flex-direction: row; align-items: center;
flex-wrap: wrap;
justify-content: center; justify-content: center;
gap: 0.25rem;
}
.user {
display: flex;
flex-grow: 1;
width: calc(50% - 0.25rem / 2);
min-width: 250px;
align-items: center; background: var(--bg-dark);
justify-content: space-between;
padding: 0.125rem 0.25rem; user-select: none;
cursor: pointer;
border: 2px solid black; z-index: 2;
} }
.user h4 { nav .nav-main .nav-item:hover {
font-size: 90%; background: var(--bg-darker);
line-height: 1;
font-family: var(--font-mono);
} }
.user a { nav .nav-main .nav-item:last-child {
text-decoration: none; grid-column: 7 / 8;
} }
.user a:hover img { nav .nav-main .nav-item.dropdown {
opacity: 0.6; position: relative;
}
.user img { z-index: 1;
margin: 0.5rem;
} }
footer { nav .nav-main .nav-item.dropdown .name {
position: absolute; width: 100%;
bottom: 0; height: 100%;
left: 0;
right: 0;
display: flex; display: flex;
flex-wrap: wrap;
align-items: center; align-items: center;
justify-content: center; justify-content: center;
background: black; background: var(--bg-dark);
color: white;
z-index: 10;
border-bottom: none;
} }
footer a, footer a:visited { nav .nav-main .nav-item.dropdown .name:hover {
color: white; background: var(--bg-darker);
} }
.footer-item { nav .nav-main .nav-item.dropdown .nav-items {
padding: 0.5rem; position: absolute;
font-size: 90%; top: 100%;
} width: 100%;
.search { display: none;
display: flex;
align-items: center;
max-width: 27rem;
margin: 1.5rem auto;
border: 2px solid black; background: var(--bg-dark);
} border-radius: 4px;
border: 1px solid #dadada;
#search-field { box-shadow: var(--shadow-1);
width: 100%;
flex-grow: 1;
height: 1.75rem;
padding: 0 0.5rem;
border: none;
border-right: 2px solid black;
} }
/*
nav .nav-main .nav-item.dropdown .nav-items::before {
position: absolute;
content: '';
top: -2px;
height: 2px;
left: 0;
right: 0;
width: 100%;
.search img { background: var(--bg-darker);
display: block; } */
transform: scale(0.8);
width: 1.75rem;
height: 1.75rem;
cursor: pointer; nav .nav-main .nav-item.dropdown .name:hover + .nav-items, nav .nav-main .nav-item.dropdown .name + .nav-items:hover {
display: flex;
flex-direction: column;
} }
/* Common */ /* .nav-main borders */
.nav-main > .nav-item:first-child {
img { border-top-left-radius: 4px;
display: block; border-bottom-left-radius: 4px;
} }
.nav-main > .nav-item:last-child {
a, a:visited { border-top-right-radius: 4px;
color: black; border-bottom-right-radius: 4px;
} }
a:hover { footer {
color: gray; position: absolute;
} bottom: 0;
left: 50%;
height: 3rem;
hr { width: 80ch;
width: 100%;
height: 1rem;
margin: 1rem 0;
padding: 0;
background: black;
border: none;
}
ul { transform: translate(-50%, 0);
list-style: square;
}
li { background: var(--bg-dark);
margin: 0.25rem 0; border-radius: 4px;
} border: 1px solid #dadada;
border-bottom: none;
box-shadow: var(--shadow-1);
form { display: flex;
margin: 3rem auto; align-items: center;
padding: 0.75rem; justify-content: center;
max-width: 30rem; border-top-left-radius: 4px;
border: 4px solid black; border-top-right-radius: 4px;
} }
form .row { /* Components */
section {
display: flex; display: flex;
width: 100%; flex-direction: column;
align-items: center;
} }
form .row:not(:last-child) { .card-list {
margin-bottom: 0.5rem; display: flex;
} flex-direction: column;
align-items: center;
form label { gap: 1rem;
width: 30%;
}
form input[type=text], form input[type=password] { margin-top: 1rem;
flex-grow: 1;
} }
form button, form input[type=submit] { .card {
margin-top: 0.5rem; background: var(--bg-dark);
} border-radius: 4px;
border: 1px solid #dadada;
box-shadow: var(--shadow-1);
input[type=text], input[type=password] { max-width: 60ch;
font-size: 15px;
padding: 0 0.2rem; padding: 1rem;
height: 1.5rem;
appearance: none;
outline: none;
border: 2px solid black; display: flex;
flex-direction: column;
} }
input[type=text]:focus, input[type=password]:focus { .card .title {
background: #e0e0e0; font-size: 22px;
font-weight: var(--font-weight-bold);
} }
button, input[type=submit] { .card .date {
outline: none; font-size: 15px;
color: #666;
font-size: 17px;
font-family: var(--font-title);
padding: 0 4rem;
height: 1.6rem;
background: black;
color: white;
border: none;
/* border: 2px solid black; */
cursor: pointer; margin-bottom: 0.75rem;
} }
button:hover, input[type=submit]:hover { .card .description {
background: #444; font-weight: var(--font-weight-light);
color: #222;
} }
/* Utils */ /* Typography */
.icons8 {
width: 25px;
height: 25px;
display: inline-block;
vertical-align: middle;
}
h2 .icons8 { h1, h2, h3, h4 {
transform: translateY(-0.125rem); margin: 0;
} margin-top: 1rem;
margin-bottom: 0.5rem;
.hfill { font-weight: var(--font-weight-light);
/* min-height: 0.5rem; */
flex-grow: 1000;
} }
@media screen and (max-width: 850px) { p {
section, nav { margin: 0.5rem 0;
border-left: none;
border-right: none;
}
} }
@media screen and (max-width: 30rem) { /* Controls */
form {
border-left: none;
border-right: none;
}
}
/* Large screen */ a {
@media screen and (min-width: 421px) { color: var(--accent-1-fg);
.nav-dropdown .dropdown { text-decoration: none;
margin-top: -2px;
}
} }
/* Mobile screen */ a:hover {
@media screen and (max-width: 420px) and (orientation: portrait) { color: var(--accent-1);
nav { text-decoration: underline;
flex-direction: column;
}
.nav-dropdown:hover {
padding: 0 0.25rem 0.25rem;
}
.nav-dropdown, .nav-dropdown .nav-item {
margin: -2px 0;
}
.nav-item, .nav-dropdown .label {
max-width: 100%;
border-left: none;
border-right: none;
}
.nav-dropdown .dropdown {
position: relative;
border: 4px solid black;
border-top-width: 2px;
}
} }

@ -34,10 +34,10 @@ func Load() {
Host = stringOrDefault(os.Getenv("HOST"), "localhost:8080") Host = stringOrDefault(os.Getenv("HOST"), "localhost:8080")
log.Printf("HOST = %v", Host) log.Printf("HOST = %v", Host)
GitUrl = stringOrDefault(os.Getenv("GIT_URL"), "git.phc.dm.unipi.it") GitUrl = stringOrDefault(os.Getenv("GIT_URL"), "https://git.phc.dm.unipi.it")
log.Printf("GIT_URL = %v", GitUrl) log.Printf("GIT_URL = %v", GitUrl)
ForumUrl = stringOrDefault(os.Getenv("FORUM_URL"), "forum.phc.dm.unipi.it") ForumUrl = stringOrDefault(os.Getenv("FORUM_URL"), "https://forum.phc.dm.unipi.it")
log.Printf("FORUM_URL = %v", ForumUrl) log.Printf("FORUM_URL = %v", ForumUrl)
} }

@ -7,15 +7,18 @@
<meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>{{ template "title" . }}</title> <title>{{ template "title" . }}</title>
<link rel="icon" href="/assets/icons/icons8-electronics-100.png"> <link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.15.4/css/all.css"
integrity="sha384-DyZ88mC6Up2uqS4h/KRgHuoeGwBcD4Ng9SiP4dIRy0EXTlnuz47vAwmeGwVChigm" crossorigin="anonymous">
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/katex@0.12.0/dist/katex.min.css" <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/katex@0.12.0/dist/katex.min.css"
integrity="sha384-AfEj0r4/OFrOo5t7NnNe46zW/tFgW6x/bCJG8FqQCEo3+Aro6EYUG4+cU+KJWu/X" crossorigin="anonymous"> integrity="sha384-AfEj0r4/OFrOo5t7NnNe46zW/tFgW6x/bCJG8FqQCEo3+Aro6EYUG4+cU+KJWu/X" crossorigin="anonymous">
<script defer src="https://cdn.jsdelivr.net/npm/katex@0.12.0/dist/katex.min.js" <script defer src="https://cdn.jsdelivr.net/npm/katex@0.12.0/dist/katex.min.js"
integrity="sha384-g7c+Jr9ZivxKLnZTDUhnkOnsh30B4H0rpLUpJ4jAIKs4fnJI+sEnkvrMWph2EDg4" integrity="sha384-g7c+Jr9ZivxKLnZTDUhnkOnsh30B4H0rpLUpJ4jAIKs4fnJI+sEnkvrMWph2EDg4"
crossorigin="anonymous"></script> crossorigin="anonymous"></script>
<script defer src="https://cdn.jsdelivr.net/npm/katex@0.12.0/dist/contrib/auto-render.min.js" <script defer src="https://cdn.jsdelivr.net/npm/katex@0.12.0/dist/contrib/auto-render.min.js"
integrity="sha384-mll67QQFJfxn0IYznZYonOWZ644AWYC+Pt2cHqMaRhXVrursRwvLnLaebdGIlYNa" integrity="sha384-mll67QQFJfxn0IYznZYonOWZ644AWYC+Pt2cHqMaRhXVrursRwvLnLaebdGIlYNa"
crossorigin="anonymous"></script> crossorigin="anonymous"></script>
<script> <script>
document.addEventListener("DOMContentLoaded", function () { document.addEventListener("DOMContentLoaded", function () {
renderMathInElement(document.body, { renderMathInElement(document.body, {
@ -36,71 +39,66 @@
<body> <body>
<nav> <nav>
<!-- Site --> <!-- Site -->
<div class="nav-item"> <div class="nav-logo">
<a href="/">PHC</a> <a href="/">
<img src="assets/images/logo-circuit-board@100w.png" alt="phc-logo">
</a>
</div> </div>
<div class="nav-main">
<div class="nav-dropdown"> <div class="nav-item">
<div class="label"> <a href="/utenti">Utenti</a>
Risorse
<img class="icons8" src="https://img.icons8.com/ios-filled/100/000000/expand-arrow.png"/>
</div> </div>
<div class="dropdown"> <div class="nav-item">
<div class="nav-item"> <a href="/news">News</a>
<a href="/blog/">Notizie</a>
</div>
<div class="nav-item">
<a href="/blog/categories/guide/">Guide</a>
</div>
</div> </div>
</div> <div class="nav-item dropdown">
<div class="name">
<div class="nav-dropdown"> <a href="/progetti">
<div class="label"> Progetti
Servizi </a>
<img class="icons8" src="https://img.icons8.com/ios-filled/100/000000/expand-arrow.png"/>
</div>
<div class="dropdown">
<div class="nav-item">
<a href="/utenti">Utenti</a>
</div>
<div class="nav-item">
<a href="https://{{ .Config.GitUrl }}">Git</a>
</div> </div>
<div class="nav-item"> <div class="nav-items">
<a href="https://{{ .Config.MatrixUrl }}">Matrix</a> <div class="nav-item">
</div> <a href="{{ .Config.GitUrl }}">Gitea</a>
<div class="nav-item"> </div>
<a href="https://{{ .Config.ForumUrl }}">Forum</a> <div class="nav-item">
<a href="{{ .Config.ForumUrl }}">Zulip</a>
</div>
<div class="nav-item">
<a href="/guide">Guide</a>
</div>
<div class="nav-item">
<a href="/seminari">Seminari</a>
</div>
</div> </div>
</div> </div>
<div class="nav-item">
<a href="/storia">Storia</a>
</div>
<div class="nav-item">
<a href="/about">About</a>
</div>
<!-- User -->
{{if .User}}
<div class="nav-item">
<a href="/profile">@{{ .User }}</a>
</div>
{{else}}
<div class="nav-item">
<a href="/login">Accedi</a>
</div>
{{end}}
</div> </div>
<!-- Spacing -->
<div class="hfill"></div>
<!-- User -->
{{if .User}}
<div class="nav-item">
<a href="/settings">@{{ .User }}</a>
</div>
{{else}}
<div class="nav-item">
<a href="/login">Accedi</a>
</div>
{{end}}
</nav> </nav>
{{ template "body" . }} <div class="main">
{{ template "body" . }}
</div>
<footer> <footer>
<div class="footer-item"> <div class="footer-item">
macchinisti@poisson.phc.dm.xxxxx.xx macchinisti@poisson.phc.dm.xxxxx.xx
</div> </div>
&centerdot;
<div class="footer-item">
Icone da <a target="_blank" href="https://icons8.it">Icons8</a>
</div>
</footer> </footer>
</body> </body>

@ -3,120 +3,82 @@
{{define "title"}}PHC &bull; phc.dm.xxxxx.xx{{end}} {{define "title"}}PHC &bull; phc.dm.xxxxx.xx{{end}}
{{define "body"}} {{define "body"}}
<section> <section>
<header> <h2>Notizie Importanti</h2>
<img class="logo" src="https://img.icons8.com/ios-filled/100/000000/electronics.png" /> <div class="card-list">
<div class="title"> <div class="card">
<h1 class="huge"> <div class="title">
PHC <a href="/news/notizia-super-wow-1">News 1</a>
</h1> </div>
<h2>Poisson</h2> <div class="date">yyyy-mm-dd</div>
<div class="description">
Lorem ipsum dolor sit amet consectetur adipisicing elit. Quis nemo aperiam, voluptas quam alias esse sed natus tempore suscipit fugiat sit delectus exercitationem numquam ipsum assumenda recusandae consequatur...
</div>
</div> </div>
</header> <div class="card">
<div class="title">
<p> <a href="/news/notizia-super-wow-2">News 2</a>
Lorem ipsum dolor sit, amet consectetur adipisicing elit. Asperiores quas nostrum suscipit nulla. Reiciendis </div>
quos et <div class="date">yyyy-mm-dd</div>
vel animi amet facere dignissimos, nemo, repudiandae suscipit esse quod obcaecati iure soluta cumque? <div class="description">
</p> Lorem ipsum dolor sit amet consectetur adipisicing elit. Quis nemo aperiam, voluptas quam alias esse sed natus tempore suscipit fugiat sit delectus exercitationem numquam ipsum assumenda recusandae consequatur...
</div>
</div>
<div class="card">
<div class="title">
<a href="/news/notizia-super-wow-3">News 3</a>
</div>
<div class="date">yyyy-mm-dd</div>
<div class="description">
Lorem ipsum dolor sit amet consectetur adipisicing elit. Quis nemo aperiam, voluptas quam alias esse sed natus tempore suscipit fugiat sit delectus exercitationem numquam ipsum assumenda recusandae consequatur...
</div>
</div>
</div>
</section> </section>
<section> <section>
<h2> <!-- TODO: Progetti/Servizi/Cose fornite -->
<img class="icons8" src="https://img.icons8.com/ios-filled/50/000000/service.png" /> <h2>Progetti</h2>
Servizi <div class="card-list">
</h2> <div class="card">
<div class="title">Project title</div>
<p> <div class="description">
Questi sono tutte le risorse e i servizi offerti dal PHC. <p>
</p> Lorem ipsum dolor sit, amet consectetur adipisicing elit. Dolorem assumenda voluptatum harum quo nisi alias ab cupiditate corrupti est, illum culpa, excepturi, fugiat dolore doloribus minima placeat facilis enim quaerat!
</p>
<div class="service-list"> </div>
<div class="service">
<h3>
<img class="icons8" src="https://img.icons8.com/ios-filled/50/000000/news.png" />
<a href="/blog">Blog & Notizie</a>
</h3>
<p>
Blog del PHC, qui sono racconte le ultime notizie sui nostri progetti recenti, informazioni su eventuali
guasti e giorni di manuntenzione.
</p>
</div>
<div class="service">
<h3>
<img class="icons8" src="https://img.icons8.com/ios-filled/50/000000/user-manual.png" />
<a href="/guides">Guide</a>
</h3>
<p>
Nel corso del tempo abbiamo scritto alcune guide utili per utilizzare Poisson o Linux in generale.
</p>
</div> </div>
<div class="service"> <div class="card">
<h3> <div class="title">Project title</div>
<img class="icons8" src="https://img.icons8.com/ios-filled/50/000000/find-user-male.png" /> <div class="description">
<a href="/utenti">Utenti</a> <p>
</h3> Lorem ipsum dolor sit, amet consectetur adipisicing elit. Dolorem assumenda voluptatum harum quo nisi alias ab cupiditate corrupti est, illum culpa, excepturi, fugiat dolore doloribus minima placeat facilis enim quaerat!
<p> </p>
Lista degli utenti di Poisson e link a relativi siti. </div>
</p>
</div> </div>
<div class="service"> <div class="card">
<h3> <div class="title">Project title</div>
<img class="icons8" src="https://img.icons8.com/ios-filled/50/000000/git.png" /> <div class="description">
<a href="https://git.phc.dm.xxxxx.xx">Git</a> <p>
</h3> Lorem ipsum dolor sit, amet consectetur adipisicing elit. Dolorem assumenda voluptatum harum quo nisi alias ab cupiditate corrupti est, illum culpa, excepturi, fugiat dolore doloribus minima placeat facilis enim quaerat!
<p> </p>
Server Git per gli utenti di Poisson, i progetti del PHC ad un certo punto verranno tenuti qui. </div>
</p>
</div>
<div class="service">
<h3>
<img class="icons8" src="https://img.icons8.com/ios-filled/50/000000/matrix-logo.png" />
<a href="https://element.phc.dm.xxxxx.xx">Matrix server</a>
</h3>
<p>
Server locale per chattare e fare videoconferenze con altre persone del dipartimento.
</p>
</div>
<div class="service">
<h3>
<img class="icons8" src="https://img.icons8.com/ios-filled/50/000000/road-worker.png" />
<a href="https://forum.phc.dm.xxxxx.xx">Forum</a>
</h3>
<p>
Forum per parlare di Matematica in \(\LaTeX\), Informatica e argomenti accademici in generale.
</p>
</div> </div>
</div> </div>
</section> </section>
<section> <section>
<h2> <div class="card">
<img class="icons8" src="https://img.icons8.com/ios-filled/50/000000/work.png" /> <div class="title">Vuoi diventare un macchinista?</div>
Macchinisti <div class="description">
</h2> <p>
Ti interessa (o interesserebbe) smanettare al PC, montare e smontare i cose? Stai spesso in dipartimento? Allora
<p> puoi venire a parlare con noi per diventare un apprendista macchinista per poi entrare nel PHC.
Al momento i macchinisti sono: </p>
</p> </div>
</div>
<ul>
<li><a href="https://poisson.phc.dm.unipi.it/~persona">Persona 1</a> dal 2018</li>
<li><a href="https://poisson.phc.dm.unipi.it/~persona">Persona 5</a> dal 2017</li>
<li><a href="https://poisson.phc.dm.unipi.it/~persona">Persona 3</a> dal 2016</li>
<li><a href="https://poisson.phc.dm.unipi.it/~persona">Persona 4</a> dal 2015</li>
<li><a href="https://poisson.phc.dm.unipi.it/~persona">Persona 6</a> dal 2014</li>
<li><a href="https://poisson.phc.dm.unipi.it/~persona">Persona 2</a> dal 2013</li>
<li><a href="https://poisson.phc.dm.unipi.it/~persona">Persona 7</a> dal 2012</li>
</ul>
<h3>Vuoi diventare un macchinista?</h3>
<p>
Ti interessa (o interesserebbe) smanettare al PC, montare e smontare i cose? Stai spesso in dipartimento? Allora
puoi venire a parlare con noi per diventare un apprendista macchinista per poi entrare nel PHC.
</p>
</section> </section>
{{end}} {{end}}
Loading…
Cancel
Save