Add Symfony payload mapping, fixtures, and QA tooling

This commit is contained in:
Bernard Ngandu
2025-10-10 08:48:27 +02:00
parent 16a8af3507
commit 49d93ffc63
48 changed files with 7456 additions and 208 deletions
+77 -60
View File
@@ -1,68 +1,85 @@
:root {
font-family: system-ui, Avenir, Helvetica, Arial, sans-serif;
line-height: 1.5;
font-weight: 400;
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');
color-scheme: light dark;
color: rgba(255, 255, 255, 0.87);
background-color: #242424;
@tailwind base;
@tailwind components;
@tailwind utilities;
font-synthesis: none;
text-rendering: optimizeLegibility;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
@layer base {
html,
body,
#root {
height: 100%;
}
a {
font-weight: 500;
color: #646cff;
text-decoration: inherit;
}
a:hover {
color: #535bf2;
}
body {
margin: 0;
display: flex;
place-items: center;
min-width: 320px;
min-height: 100vh;
}
h1 {
font-size: 3.2em;
line-height: 1.1;
}
button {
border-radius: 8px;
border: 1px solid transparent;
padding: 0.6em 1.2em;
font-size: 1em;
font-weight: 500;
font-family: inherit;
background-color: #1a1a1a;
cursor: pointer;
transition: border-color 0.25s;
}
button:hover {
border-color: #646cff;
}
button:focus,
button:focus-visible {
outline: 4px auto -webkit-focus-ring-color;
}
@media (prefers-color-scheme: light) {
:root {
color: #213547;
background-color: #ffffff;
color-scheme: dark;
--background: 222.2 84% 4.9%;
--foreground: 210 40% 98%;
--card: 222.2 84% 6.5%;
--card-foreground: 210 40% 96%;
--popover: 222.2 84% 6.5%;
--popover-foreground: 210 40% 96%;
--primary: 199 89% 62%;
--primary-foreground: 222.2 47.4% 11.2%;
--secondary: 217.2 32.6% 17.5%;
--secondary-foreground: 210 40% 96%;
--muted: 223 50% 12%;
--muted-foreground: 215 20.2% 65.1%;
--accent: 199 89% 62%;
--accent-foreground: 222.2 47.4% 11.2%;
--destructive: 0 84.2% 60.2%;
--destructive-foreground: 210 40% 98%;
--border: 221.6 30% 23%;
--input: 221.6 30% 23%;
--ring: 199 89% 62%;
--radius: 0.8rem;
font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}
a:hover {
color: #747bff;
* {
@apply border-border;
}
button {
background-color: #f9f9f9;
body {
@apply min-h-screen bg-background bg-radial-signal text-foreground antialiased;
}
p {
@apply leading-relaxed;
}
.leaflet-container {
font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}
.leaflet-tooltip {
background: rgba(15, 23, 42, 0.9);
border: 1px solid rgba(148, 163, 184, 0.35);
color: #e2e8f0;
border-radius: 0.75rem;
box-shadow: 0 15px 35px rgba(2, 6, 23, 0.45);
padding: 0.65rem 0.75rem;
}
.leaflet-tooltip-top:before,
.leaflet-tooltip-bottom:before,
.leaflet-tooltip-left:before,
.leaflet-tooltip-right:before {
border-top-color: rgba(15, 23, 42, 0.9);
border-bottom-color: rgba(15, 23, 42, 0.9);
border-left-color: rgba(15, 23, 42, 0.9);
border-right-color: rgba(15, 23, 42, 0.9);
}
}
@layer utilities {
.status-dot::after {
content: '';
position: absolute;
inset: -0.35rem;
border-radius: 9999px;
border: 1px solid currentColor;
opacity: 0.35;
animation: status-pulse 2.4s ease-out infinite;
}
}