Les illustrations doivent être en 16:9, au format 1280 ⨉ 720 pixels, optimisées au préalable avec un outil du type ImageOptim - choisir des réglages "lossy" donnant en général plus de 50% de gains à la compression, mais ne pas supprimer les métadonnées d'images.
Sinon, offline : dupliquer un fichier de description dans le dossier
_startup
et suivre les instruction ci-dessous sur l'édition.
Pour le titre de la startup, s'en tenir aux règles usuelles, c'est-à-dire sauf cas particuliers : le premier mot prend une majsucule, les autres non. (Ce n'est pas grave de se tromper, mais il faut s'attendre à ce que ça soit corrigé plus tard.)
Pour l'énoncé de mission, utiliser une phrase à l'infinitif, qui complète « En investissant dans ce produit, l'État cherche à… » ou « l'État cherche à rendre plus facile de… ».
Modifier le fichier $id_startup.md
de description de la Startup dans le dossier _startup
.
La documentation des différentes propriétés à renseigner est accessible en cliquant sur le lien de création d'une nouvelle Startup dans la section précédente.
En un clic par l'interface web de GitHub 😃
Pour ajouter une image au billet, créer un fichier JPEG dans img/posts
du même nom que le fichier contenant le post (donc par exemple AAAA-MM-DD-titre.jpg
). À l'affichage, l'image sera redimensionnée : les dimensions exactes de l'image ont donc peu d'importance.
Sinon, offline : créer un nouveau post dans le dossier
_posts
.
Avant d'ouvrir une pull request, diffuser un lien privé de prévisualisation à [email protected]
.
Par exemple, créer un Gist privé.
Recueillez l'avis d'au moins 2 membres de l'incubateur. Après de potentielles itérations, si aucun des destinataires n'a posé de véto à la publication, l'auteur peut ouvrir une pull request pour dernières vérifications syntaxiques et fonctionnelles.
Un événement est un type de billet particulier. Il a donc quelques métadonnées supplémentaires (start
, end
…), mais est équivalent pour le reste, dont l'ajout d'images et la création offline.
Notamment, attention, la date dans le nom du fichier au format AAAA-MM-DD-nom_evenement.md
est la date à laquelle vous souhaitez que l'événement soit annoncé sur le site (et non la date de l'événement lui-même).
Le nom du fichier est important : il doit correspondre au nom de la personne, selon le schéma prenom.nom
. Les parties prenom
et nom
sont en minuscules et sans accents. Les espaces des noms propres sont remplacés par _
et les tirets restent. Rien de très important ne dépend du respect de ces conventions, par contre il est important que cet identifiant et celui du mail @beta.gouv.fr
correspondent. Cela nous permet de traiter automatiquement divers sujets liés à la gestion RH tels que abonnement et désabonnement des listes de diffusion, anticipation des fins de contrat, etc.
Sinon, offline : créer un nouveau fichier de description dans le dossier
_authors
et renseigner les informations en prenant exemple sur un fichier de description existant déjà dans ce dossier.
Tu peux fournir un fichier avec ta photo si tu n'as pas de compte Github, ou si tu es à l'aise avec la manip (qui est un peu plus pénible que juste modifier un fichier Markdown). Attention, l'image doit être carrée et de préférence à une résolution supérieure à 512 ⨉ 512 pixels, optimisée au préalable avec un outil du type ImageOptim - choisir des réglages "lossy" donnant en général plus de 50% de gains à la compression, mais ne pas supprimer les métadonnées d'images.
Une fois l'offre pourvue, bien penser à changer la valeur du flag
open
et de la mettre àfalse
.
S'il s'agit d'une offre dev, merci d'ajouter le flag
techno
.
Pour un premier recrutement (le CTO de la Startup), la valeur conseillée de ce champ est "Choix technologiques ouverts parmi les solutions libres du marché."
Pour les recrutements ultérieurs, vous pouvez préciser s'ils sont ouverts aux débutant·e·s. Le recrutement de ces profils "juniors" est un élément important pour augmenter la diversité au sein de notre collectif ; prenez le temps de réfléchir à vos besoins pour ce recrutement avant d'écarter cette possibilité.
Rechercher le contenu à modifier et éditer le fichier correspondant.
Mettre à jour la propriété featured
de la phase correspondante pour référencer le nom du fichier dans lequel la startup à mettre en avant est décrite dans index.html
.
Attention, toutes les pages doivent avoir, dans leur front matter, les variables permalink
, lang
et ref
définies.
Ce site est construit avec Jekyll, un générateur de sites statiques. La version utilisée est celle actuellement en production sur GitHub Pages.
Pour l'améliorer, installer Ruby et Jekyll dans leurs versions de production :
git clone https://github.com/betagouv/beta.gouv.fr.git
cd beta.gouv.fr
gem install bundler --no-ri --no-rdoc
bundle install
bundle exec jekyll serve
Les fichiers pertinents pour une modification de la présentation sont probablement dans les dossiers _layouts
et css
.
- Installer (Docker](https://docs.docker.com/compose/install/) (Docker compose est normalement installé automatiquement avec Docker)
- Lancer
docker-compose up
Afin de minimiser les écarts entre les versions de développement et les versions de production, ce dépôt contient un fichier Gemfile
(spécification des versions minimum des dépendances), comme beaucoup de dépôts Ruby. Ce fichier Gemfile
a par ailleurs un fonctionnement un peu particulier : lorsque c'est possible, il obtient sur le site de Github le numéro de version de Github Pages le plus récent, et tente de mettre à jour les dépendances.
Pour encourager les contributions, éviter les erreurs d'inattention, et se mettre d'accord collectivement sur le contenu publié au nom de l'incubateur, chaque modification doit être relue et approuvée par une autre personne que l'auteur avant d’être intégrée.
Pour les relectures de code, il vaut mieux choisir une personne ayant un peu l'habitude de Jekyll, de Ruby ou du développement web. En revanche, en cas d'urgence sur une relecture éditoriale, toute personne de l'incubateur est légitime à approuver les modifications.
L'auteur d'une modification est responsable de pousser pour obtenir une relecture, en relançant les gens périodiquement. Pour demander une relecture :
- Ouvrir une pull request, sans mentionner de relecteur explicitement. Les relecteurs potentiels vont recevoir une notification, et peuvent s'auto-assigner la relecture.
- Si plusieurs jours s'écoulent sans relecture (entre 2 et 5 jours, à la louche), ajouter un commentaire à la pull request, en demandant explicitement une relecture à un relecteur potentiel.
- Si plusieurs jours s'écoulent à nouveau, contacter directement un relecteur potentiel (par exemple par message privé sur le Slack de l'incubateur, ou en présentiel dans les locaux de beta.gouv.fr).
- Commentez le code ou le texte – pas l'auteur : on ne cherche pas à assigner de responsabilités ou à critiquer l'auteur ; mais juste à voir comment un bout de code ou de texte pourrait être plus pertinent.
- Si vous critiquez, proposez : si quelque chose ne vous plait pas, expliquez comment vous proposeriez de l'améliorer.
- Soyez souple : si vous avez une remarque mineure, ne bloquez pas la pull request avec une revue négative. Il vaut mieux approuver la pull request, en laissant l'auteur responsable de prendre en compte (ou pas) vos remarques.
Chaque pull request est déployée dans Heroku, une fois le build passé. Une notification est envoyée sur la pull request :
Vous pouvez suivre le lien de la notification pour accéder à la version de l'application correspondant à la pull request.
Ce site est déployé en continu avec Github Pages. La branche qui reflète la production est master
.
Pousser sur master
, c’est partager avec le monde… ce qui signifie donc qu'il faut être très prudent avec ce pouvoir et privilégier l'usage de pull requests 😉
C'est pourquoi la branche master
est protégée : il est impossible de mettre en production sans que les tests automatisés n'aient validé que le site pouvait être généré correctement et qu'au moins un pair humain ait revu les modifications proposées.