Introduction

Et il va nous sortir quoi de son chapeau ce bon monsieur ? Le problème il était de faire une page internet^W oueb statique hein !

Que des choses indispensables pour briller en société ! En l'occurence l'utilisation de bundler et guard et, histoire d'aller un peu plus loin, un peu de coffeescript parce qu'on le mérite bien.

Bendleure

Comme vous avez pu le remarquer, la génération de votre page html nécessitait l'utilisation de plusieurs gem ruby en l'occurrence :

Il était donc nécessaire de réaliser deux actions manuelles pour les installer. Mais les commandes c'est surfait, tout le monde le sait !

Heureusement bundler est là pour nous ! Tout d'abord, étant donné que c'est également une gem, il faut l'installer :

gem install bundler

Ha oui, je vous vois venir !

Oué mais l'autre il nous dit qu'on va supprimer l'installation manuelle des gem et il ne trouve rien de mieux à faire que d'installer une nouvelle gem !

Et là de répondre :

C'est pas faux

D'ailleurs, vous allez même créer un nouveau fichier, Gemfile qui contiendra le code suivant :

source 'https://rubygems.org'
gem 'haml'
gem 'sass'

Vous pouvez désormais installer ces deux gem via la commande :

bundle

C'est 'achement plus facile, non ?

Cette commande va vous installer les deux gem si vous ne les aviez pas déjà et va créer un fichier Gemfile.lock qui contient les installations réalisées et leur version. Si un tel fichier n'existe pas, bundler va essayer de récupérer la dernière version des gem. Si un fichier lock existe déjà, il va essayer d'installer la version spécifiée dans le fichier. L'avantage est que si vous partagez ce fichier entre vos différents environnements (par exemple en le versionnant dans votre git) il vous assure d'avoir les mêmes dépendances partout. Et ça c'est bien !

Développer votre page statique est donc d'autant plus aisée qu'il vous suffit de faire un clone de votre git et d'exécuter bundler (de toute façon, qui n'a pas bundler sur sa machine aujourd'hui ?).

Moins j'en fait, mieux je me porte !

Etant donné que vous êtes une vrai feignasse, vous n'avez surtout pas envie de devoir relancer rake à chaque modification réalisée (car le temps gagné pourra être passé à mouler^W faire sa veille technologique).

La première chose est donc d'ajouter guard a votre Gemfile (vous voyez que finalement ça sert à quelque chose bundler) et l'installer via bundle.

gem 'guard'

La deuxième chose est d'initialiser guard. Une bonne pratique est de toujours utiliser bundler pour exécuter guard. Vous n'allez donc pas exécuter guard init mais

bundle exec guard init

Ceci va vous créer un fichier Guardfile qui va bien (mais qui ne fait rien).

Je vous conseil d'aller voir la documentation de guard car un certain nombre d'usages classiques sont déjà supportés et leur mise en oeuvre est vraiment simple. Dans notre cas, on utilise rake pour construire notre page statique. Tout naturellement nous allons donc nous tourner vers le plugin guard-rake.

Dans le Gemfile rajouter

gem 'guard-rake'

et exécuter bundle.

Ensuite, initialiser le Guardfile avec guard-rake :

bundle exec guard init rake

Vous devez donc avoir un fichier Guardfile qui contient

guard 'rake', :task => 'build' do
  watch(%r{^my_file.rb})
end

J'espère que vous avez déjà compris ce que ça voulait dire : lorsque le/les fichiers surveillés par watch seront modifiés, rake sera executé avec la cible build. Parfais, c'est exactement ce qu'on cherche à faire !

Il ne reste donc plus qu'à modifier un peu le watch pour que ça corresponde à notre cas :

guard 'rake', :task => 'build' do
  watch %r{^index.haml$}
  watch %r{^css/(.+)\.sass$}
end

De cette manière, dès que index.haml ou l'un des fichiers sass va être modifié, rake va être exécuté.

Faisons un petit test. Tout d'abord il convient de lancer guard :

bundle exec guard

Et voilà ! A chaque fois que vous modifierez un des fichiers surveillés, la sortie sera regénérée ! Le gain en terme de confort est loin d'être négligeable, c'est vraiment un plus pour développer correctement une page oueb statique !

L'inter a ctivité

Comme on est pas des mickeys on va faire les choses en grand : on va rajouter un peu d'interactivité et de fun dans cette page tristounette !

Pour ce faire, on va rajouter un peu de code côté client. Mais bon, tout le monde le sait, le javascript c'est has been. On va donc le faire en coffeescript !

Tout d'abord, créer un répertoire js (oui, js, pas coffee) et dedans un fichier mickey.coffee.

Dans ce fichier, écrire le contenu suivant :

init = ->
  img = document.createElement 'img'
  img.src = ""
  img.style.position = 'absolute'
  img.style.top = '-1000px'
  img.style.left = '-1000px'
  document.body.appendChild img
  
  window.onmousemove = (e) ->
    img.style.left = "#{e.clientX + 10}px"
    img.style.top  = "#{e.clientY + 10}px"
  
init()

Bon, c'est bien joli mais comment on l'intègre ?

Déjà, on va rajouter la gem qui va bien à bundler :

gem 'coffee-script'

Puis l'installer :

bundle

Ensuite, il faut compiler le tout en javascript. Dans le fichier Rakefile ajouter en tête

require 'coffee-script'

Et ajouter à la tâche :build :

js = CoffeeScript.compile File.read("js/mickey.coffee")
File.open("_site/mickey.js", "w") { |f| f.write(js) }

Enfin, appeler le script dans la page web. Pour ce faire, ajouter une balise script pointant vers mickey.js à la fin du fichier :

%script(src="mickey.js")

Il reste une dernière petite chose à faire, l'ajouter au Guardfile

watch %r{^js/mickey\.coffee$}

Désormais c'est fait ! Vous avez donc une super animation de haute voltige sur votre page web statique !

Conclusion

It's time to kick ass and chew bubble gum, and I'm all outta gum !

Et voilà, tout roule. Vous avez enfin une page web statique de très haut niveau. A ce stade vous pouvez travailler parmis les meilleurs et vous avez désormais une justification pour le prix de vos oeuvres d'art.

Et sinon, ben vous aurez juste eu l'occasion de découvrir certaines technologies plutôt cool au travers d'une réalisation totalement inutile ;)

Les sources utilisées sont disponibles sur un dépôt github et le résultat tant attendu est visible