TP Framework CSS

Les Frameworks CSS

Pour créer des pages Web de qualité rapidement, on peut s’aider d’outils comme les Frameworks CSS qui facilitent la génération de contenu web et donnent rapidement un rendu visuel acceptable.

Un framework Web nous donne principalement accès à deux types de fonctionnalités :

  1. il permet la création rapide et facile de composants graphiques élaborés (bares de navigation, panneaux, grilles, boites, listes, onglets, …)
  2. il respecte un style graphique qui unifie tous les éléments visuels de la page en respectant un style donné (un styleguide ou Design Language).

Les styleguides sont publiés par différents acteurs du Web. Parmi les dizaines de guides qui existent on peut citer :

Il existe un bon nombre de Frameworks CSS. Parmi eux :

Design de pages Web Responsive

Un site web dont le design est responsive propose d’adapter visuellement l’affichage en fonction du support d’affichage (l’écran). On n’écrit pas plusieurs versions du site en fonction du support mais on inclue dans le code source (HTML et CSS) les règles d’affichages conditionnelles en fonction du support. En CSS les media querries permettent d’avoir du style conditionnel.

Le Framework Bulma

Installation

Dans sa version la plus simple, Bulma est un simple fichier CSS. Il suffit donc de l’inclure dans une page html pour l’utiliser.

Créer un dossier de travail ( TP-Framework-CSS par exemple) et y ajouter un fichier index.html avec ce contenu minimal :

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>Hello Bulma!</title>
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bulma@1.0.2/css/bulma.min.css">
  </head>
  <body>
  <section class="section">
    <div class="container">
      <h1 class="title">
        Hello World
      </h1>
      <p class="subtitle">
        My first website with <strong>Bulma</strong>!
      </p>
    </div>
  </section>
  </body>
</html>

Documentation

Se référer à la documentation de bulma pour obtenir un panel de toutes les fonctionnalités du Framework.

Travail à réaliser

On se propose de créer un site Web en HTML et CSS statique (pas de PHP) qui permet de présenter les équipes les matchs et les groupes de la Coupe du monde d’Aérospike qui aura lieu en 2036 à Néo-Singapour, une ville flottante futuriste.

Aérospike est un sport d’équipe qui mélange les éléments du basketball, de la course aérienne et du jeu de stratégie. Il se joue sur une immense plateforme flottante équipée de systèmes de gravité ajustable. Les joueurs, munis de chaussures anti-gravité et de gants propulseurs, doivent marquer des points en envoyant une sphère lumineuse (le “Spike”) dans des cercles suspendus appelés “Arches Dynamiques”. Ces Arches changent de position toutes les 90 secondes, ajoutant un défi stratégique et physique.

La première phase de la compétition se déroule en poules de 4 équipes. Les matches se jouent en round-robin. Les équipes qualifiées passent dans les phases suivantes de la compétition.

Le but de ce TP est de réaliser plusieurs pages sur ce sujet en utilisant le Framework CSS Bulma. Ce site possède plusieurs pages ou ensemble de pages liées entre elles. Le design doit respecter celui proposé par Bulma. Un maximum de composants et d’éléments graphiques doivent être utilisés. Les pages sont “responsives” et utilisent le système de colonnes du Bulma.

Toutes les pages ont la même base graphique avec une entête contenant un logo et un titre. Le logo devient centré et le titre passe sur la seconde ligne en mode étroit (mobile). Chaque page propose un menu latéral qui disparaît en mode étroit (mobile).

La page des groupes

La page des groupes présente tous les groupes, les équipes et leur drapeau en une seule page. Deux groupes par ligne sont affichés, en mode large (desktop) et un groupe par ligne en mode étroit (mobile).

La page des groupes en mode large :

groupes mode large

La page des groupes en mode étroit :

groupes mode étroit

Une page par groupe

Chaque groupe a sa propre page sous forme d’un onglet d’un composant tab. Dans chaque page figure à minima un tableau des matchs avec le nom des équipes, la date et le lieux des matchs.

Exemple d’une page du groupe, à minima, en mode desktop :
Groupe A mode Large

Pas la peine d’écrire toutes les pages de groupes. Une seule suffit.

Les pages équipe

A vous d’imaginer ce qu’une page équipe peut afficher en utilisant les éléments et composants de Bulma. Vous pouvez vous inspirer de Wikipedia (e.g. Équipe de Football du Sénégal) pour constater qu’une équipe possède un emblème, des couleurs, un sélectionneur, un capitaine, un classement internationale, etc. Pas la peine d’écrire toutes les pages équipes. Une seule suffit.

Pour aller plus loin

Bulma nous permet d’obtenir des pages Web stylisées très rapidement. Mais bulma est configurable à volonté. On peu en effet changer le thème graphique, les tailles les polices, les couleurs, etc. Pour cela il ne faut plus utiliser le fichier CSS pré-compilé de Bulma. Il faut modifier/configurer et compiler le fichier source au format SASS : un langage de description puissant qui permet de produire du CSS.

Bulma Start

On utilise le projet Bulma Start pour obtenir un projet de base fonctionnel.

On se place dans un dossier de travail dans lequel on va créer le projet :

cd dossier/de/travail # c'est vous qui décidez

On télécharge le projet depuis github, puis on retire l’historique GIT :


git clone https://github.com/jgthms/bulma-start TP-Framework-CSS

cd TP-Framework-CSS

rm -rf .git/

On peut maintenant installer Bulma Start :

npm install # oui ça prend du temps...
npm start # ça bloque le termial, c'est normal

Ce terminal est bloqué, c’est normal, on le laisser ouvert.

Ouvrir un explorateur de fichier dans le dossier TP-Framework-CSS pour inspecter la structure du projet :

et ouvrir un éditeur de texte pour voir les fichiers et un navigateur qui pointe sur le fichier index.html.

SASS / CSS

Le code CSS n’est pas directement utilisé lors du développement. On utilise un langage intermédiaire (ici, SASS) qui va être compilé en CSS à la volée. Quand on modifie le fichier _sass/main.scss le fichier css/main.css est automatiquement régénéré. Il ne faut donc pas modifier directement le fichier css/main.css car il sera écrasé. Le format de fichier scss de SASS permet d’écrire du code CSS classique et de profité des avantages de SASS (variables, mixins, etc.)

L’utilisation de SASS permet de modifier les variables définies par Bulma. Ces variables sont définies dans les fichiers node_modules/bulma/sass/utilities/initial-variables.sass et node_modules/bulma/sass/utilities/derived-variables.sass. On peut les redéfinir pour personnaliser le thème visuel de nos pages. Dans _sass/main.scss on va commencer par modifier ces variables et en premier lieux les couleurs de base :

// 1. Choisissez vos propre couleurs
$purple: #8A4D76;
$pink: #FA7C91;
$brown: #757763;
$beige-light: #D0D1CD;
$beige-lighter: #EFF0EB;

// 2. modifier les variables de Bulma par défaut
$primary: $purple;
$grey-dark: $brown;
$grey-light: $beige-light;
$link: $pink;
$widescreen-enabled: false;
$fullhd-enabled: false;

// 4. modifier plus précisément les valeurs par défaut du thème
$body-background-color: $beige-lighter;
$control-border-width: 2px;
$input-border-color: transparent;
$input-shadow: none;

// 5. Import the rest of Bulma

@import "../node_modules/bulma/bulma";