From ca60e3088da8d9657c0d2883493d29aff79140e7 Mon Sep 17 00:00:00 2001 From: Pierre-Olivier Mercier Date: Sun, 17 May 2026 21:46:29 +0800 Subject: [PATCH] WIP new home page design --- config.yml | 20 +- data/features.toml | 80 +++---- i18n/en.yaml | 7 +- i18n/fr.yaml | 5 +- layouts/index.html | 6 +- layouts/partials/big-idea.html | 72 +++++++ layouts/partials/features.html | 86 ++++---- layouts/partials/jumbo.html | 5 +- layouts/partials/nav.html | 53 +++-- layouts/partials/work-with.html | 18 ++ static/css/custom.css | 369 +++++++++++++++++++++++++++++--- 11 files changed, 565 insertions(+), 156 deletions(-) create mode 100644 layouts/partials/big-idea.html create mode 100644 layouts/partials/work-with.html diff --git a/config.yml b/config.yml index 9951658..4a92e15 100644 --- a/config.yml +++ b/config.yml @@ -34,14 +34,12 @@ languages: DefaultDescription: "L'interface qui vous rend heureux de gérer vos noms de domaines." others_links: - - text: "S'inscrire" - href: "//app.happydomain.org/register" - class: "btn btn-secondary" - icon: "bi-person-plus-fill" - text: "S'identifier" href: "//app.happydomain.org/login" - class: "btn btn-outline-primary" - icon: "bi-person-check-fill" + class: "btn btn-link text-dark" + - text: "Essayer en ligne →" + href: "//try.happydomain.org/" + class: "btn btn-primary btn-sm" carousel: - title: "domains-lists" @@ -90,14 +88,12 @@ params: tryit: "https://try.happydomain.org/" others_links: - - text: "Sign up" - href: "//app.happydomain.org/register" - class: "btn btn-secondary" - icon: "bi-person-plus-fill" - text: "Sign in" href: "//app.happydomain.org/login" - class: "btn btn-outline-primary" - icon: "bi-person-check-fill" + class: "btn btn-link text-dark" + - text: "Try it online →" + href: "//try.happydomain.org/" + class: "btn btn-primary btn-sm" carousel: - title: "domains-lists" diff --git a/data/features.toml b/data/features.toml index 3189ad4..474234a 100644 --- a/data/features.toml +++ b/data/features.toml @@ -8,12 +8,12 @@ id = "registrar" en = "Choose your provider" [features.title] - fr = "Gérer les zones hébergées chez des prestataires d'hébergement" - en = "Manage your zones hosted on hosting providers" + fr = "Gérer les zones de votre fournisseur de noms de domaine" + en = "Manage zones at your registrar" [features.content] - fr = "happyDomain peut regrouper les domaines que vous possédez dans différents bureaux d'enregistrement. Nous supportons aujourd'hui plus de 55 fournisseurs tels que OVH, Gandi, DigitalOcean, ..." - en = "happyDomain can group the domains you own in different registrars. We currently support 55+ providers like OVH, Gandi, DigitalOcean, ..." + fr = "Connectez OVH, Gandi, DigitalOcean, Cloudflare et plus de 50 autres. happyDomain lit, édite et synchronise les zones pour vous." + en = "Connect OVH, Gandi, DigitalOcean, Cloudflare and 50+ more. happyDomain reads, edits and synchronizes their zones for you." [features.link] link = "https://app.happydomain.org/providers/features" @@ -32,16 +32,16 @@ id = "dynamicDNS" [features.img] src = "/img/screenshots/features/dyndns.png" [features.img.alt] - fr = "Une interface au dessus de votre serveur existant" - en = "An interface on top of your existing server" + fr = "Gérez votre propre serveur de noms" + en = "Drive your own name server" [features.title] fr = "Gérer les zones de vos serveurs BIND, Knot, PowerDNS, ..." en = "Manage your zones backed by BIND, Knot, PowerDNS, ..." [features.content] - fr = "happyDomain peut s'utiliser comme interface au dessus d'un serveur faisant autorité. Il utilise pour cela le Dynamic DNS (RFC 2136), implémenté dans de nombreux serveurs." - en = "happyDomain can be used as an interface above an authoritative name server. It uses the Dynamic DNS (RFC 2136), implemented in many server software." + fr = "Utilisez happyDomain comme interface conviviale devant BIND, Knot ou PowerDNS via le DNS dynamique (RFC 2136). Implémenté dans de nombreux serveurs faisant autorité." + en = "Use happyDomain as a friendly UI in front of BIND, Knot or PowerDNS via Dynamic DNS (RFC 2136). Implemented in many authoritative servers." [features.link] link = "https://help.happydomain.org/fr/deploy/" @@ -59,12 +59,12 @@ id = "diff" en = "Sample diff" [features.title] - fr = "Visualiser clairement les changements" - en = "Clearly visualize changes" + fr = "Visualiser chaque changement" + en = "Visualize every change" [features.content] - fr = "Avant de publier vos modifications, happyDomain vous montre quels seront exactement les changements (ajouts, modifications, suppressions, ...) qui seront effectués sur la zone. C'est le bon moment pour se relire." - en = "Before publishing your changes, happyDomain shows you exactly what changes (additions, modifications, deletions, ...) will be made to your zone. This is a good time to reread." + fr = "Avant de publier, vérifiez précisément quels enregistrements seront ajoutés, modifiés ou supprimés. Vous pouvez relire attentivement les changements avant d'appuyer sur le bouton." + en = "Before publishing, see exactly which records will be added, modified or deleted. Read-through your zone before you press the button." [[features]] @@ -77,8 +77,8 @@ id = "resolver" en = "DNS Resolver" [features.title] - fr = "Tester ou déboguer votre zone en ligne" - en = "Test or debug your zone online" + fr = "Tester et déboguer votre zone" + en = "Test & debug your zone" [features.content] fr = "happyDomain intégre un résolveur DNS simple d'utilisation, qui vous permet de vous connecter sans effort à une cinquantaine de résolveurs publics. Vous pouvez facilement voir la propagation de vos modifications." @@ -90,29 +90,6 @@ id = "resolver" en = "I want to test this now!" -[[features]] -id = "rest" - - [features.img] - src = "/img/screenshots/features/rest.png" - [features.img.alt] - fr = "API REST" - en = "REST API" - - [features.title] - fr = "Utiliser happyDomain comme API REST" - en = "Use happyDomain as a API REST" - - [features.content] - fr = "happyDomain expose une API REST que vous pouvez utiliser pour automatiser des tâches de création de sous-domaine à la volée, par exemple dans votre système de déploiement continu." - en = "happyDomain exposes a REST API that you can use to automate sub-domain creation tasks on the fly, for example in your continuous deployment system." - - [features.link] - link = "https://app.happydomain.org/swagger/index.html" - fr = "Montrez-moi l'API !" - en = "Show me the API!" - - [[features]] id = "history" @@ -124,8 +101,31 @@ id = "history" [features.title] fr = "Garder une trace des modifications" - en = "Keeping track of changes" + en = "Versioned, undoable" [features.content] - fr = "happyDomain ne se contente pas de vous montrer votre zone telle qu'elle est publiée. Chaque modification est enregistrée afin de garder un historique de vos changements. En cas de problème, revenez à une version précédente en 2 clics." - en = "happyDomain doesn't just show you your zone as it is published. Every modification is saved to keep a history of your changes. In case of problem, go back to a previous version in 2 clicks." + fr = "Chaque modification publiée est enregistrée. Revenez à n'importe quelle version précédente de votre zone en deux clics. Auditez qui a effectué quelles modifications." + en = "Every published change is saved. Roll back to any previous version of your zone in two clicks. Audit who did what." + + +[[features]] +id = "rest" + + [features.img] + src = "/img/screenshots/features/rest.png" + [features.img.alt] + fr = "API REST" + en = "REST API" + + [features.title] + fr = "API REST, scripter vos domaines" + en = "REST API, ready to script" + + [features.content] + fr = "Automatisez la création de domaines à la volée : idéal pour le déploiement continu et la mise en place de locataires." + en = "Automate domain creation tasks on the fly: perfect for continuous deployment and tenant provisioning." + + [features.link] + link = "https://app.happydomain.org/swagger/index.html" + fr = "Montrez-moi l'API !" + en = "Show me the API!" diff --git a/i18n/en.yaml b/i18n/en.yaml index 5031a24..06d2899 100644 --- a/i18n/en.yaml +++ b/i18n/en.yaml @@ -45,12 +45,15 @@ - id: press-kit translation: "Press Kit" -- id: features-title +- id: features-eyebrow translation: "Main features" +- id: features-title + translation: "Everything DNS, calm and connected." + - id: features-lead translation: | - Find out how happyDomain can simplify your domain name management. + happyDomain works as a smart layer above your existing infrastructure: connecting to registrars, hosting providers and authoritative servers so you can manage them all from one place. - id: features-grid-title translation: What can happyDomain do for you today? diff --git a/i18n/fr.yaml b/i18n/fr.yaml index f9ad14d..b5ddb35 100644 --- a/i18n/fr.yaml +++ b/i18n/fr.yaml @@ -45,9 +45,12 @@ - id: press-kit translation: "Dossier de presse" -- id: features-title +- id: features-eyebrow translation: "Principales fonctionnalités" +- id: features-title + translation: "Tout le DNS, sereinement connecté." + - id: features-lead translation: "Découvrez comment happyDomain peut faciliter la gestion de vos noms de domaine." diff --git a/layouts/index.html b/layouts/index.html index 4096a74..8ba8d90 100644 --- a/layouts/index.html +++ b/layouts/index.html @@ -13,10 +13,14 @@ {{ partial "jumbo.html" . }} - {{ partial "carousel.html" . }} + {{ partial "work-with.html" . }} + + {{ partial "big-idea.html" . }} {{ partial "features.html" . }} + {{ partial "carousel.html" . }} + {{ partial "discover.html" . }} {{/* partial "testimonials.html" . */}} diff --git a/layouts/partials/big-idea.html b/layouts/partials/big-idea.html new file mode 100644 index 0000000..479847b --- /dev/null +++ b/layouts/partials/big-idea.html @@ -0,0 +1,72 @@ + +
+
+
+ The big idea +

Stop reading zone files.
Start managing services.

+

DNS records are an implementation detail. happyDomain groups them by what they actually do — your email, your website, your delegation — so you can edit with intent instead of decoding RFCs.

+
+ +
+
+
AWithout happyDomain
+

happydomain.org · zone file

+
; Zone: happydomain.org.
+; TTL = 3600
+
+@      IN SOA   ns1 admin 2024010101 3600 900 604800 300
+@      IN NS    ns1.happydomain.org.
+@      IN NS    ns2.happydomain.org.
+@      IN A     93.184.216.34
+@      IN AAAA  2606:2800:220:1:248:1893:25c8:1946
+@      IN MX    10 mail.happydomain.org.
+@      IN TXT   "v=spf1 include:_spf.eu ~all"
+_dmarc IN TXT   "v=DMARC1; p=none; rua=…"
+mail   IN A     93.184.216.40
+www    IN CNAME @
+@      IN CAA   0 issue "letsencrypt.org"
+
+
+
BWith happyDomain
+

happydomain.org · services

+
+
+
+
+
Website
A, AAAA on @ · CNAME on www
+
+
3 OK
+
+
+
+
+
+
+
Email
MX, SPF and DMARC policy
+
+
3 OK
+
+
+
+
+
+
+
Delegation
2 nameservers
+
+
2 OK
+
+
+
+
+
+
+
TLS / Security
CAA · Let's Encrypt only
+
+
1 OK
+
+
+

Same zone. Edit by intent, not by record type.

+
+
+
+
diff --git a/layouts/partials/features.html b/layouts/partials/features.html index 247c6a5..844a29f 100644 --- a/layouts/partials/features.html +++ b/layouts/partials/features.html @@ -1,48 +1,11 @@ -
-
-
-

{{ i18n "features-title" }}

-
-

- {{ i18n "features-lead" }} -

-
-
- -
-
🏗️
-
-

{{ i18n "features-wip-lead" }}

-

- {{ i18n "features-wip-p1-start" }} - {{ i18n "features-wip-p1-strong" }} - {{ i18n "features-wip-p1-link" }}. - {{ i18n "features-wip-p1-end" }} -

-

- {{ i18n "features-wip-p2-feedback" }} - {{ i18n "features-wip-p2-start" }} - {{ i18n "features-wip-p2-emph" }}{{ i18n - "features-wip-p2-end" }} -

-
+
+
+
+ {{ i18n "features-eyebrow" }} +

{{ i18n "features-title" }}

+

{{ i18n "features-lead" }}

@@ -86,5 +49,38 @@
{{ end }} {{ end }}
+ +
+
🏗️
+
+

{{ i18n "features-wip-lead" }}

+

+ {{ i18n "features-wip-p1-start" }} + {{ i18n "features-wip-p1-strong" }} + {{ i18n "features-wip-p1-link" }}. + {{ i18n "features-wip-p1-end" }} +

+

+ {{ i18n "features-wip-p2-feedback" }} + {{ i18n "features-wip-p2-start" }} + {{ i18n "features-wip-p2-emph" }}{{ i18n + "features-wip-p2-end" }} +

+
+
diff --git a/layouts/partials/jumbo.html b/layouts/partials/jumbo.html index 2398ebf..53e71f2 100644 --- a/layouts/partials/jumbo.html +++ b/layouts/partials/jumbo.html @@ -1,7 +1,6 @@