Un processus d’agence survitaminé et complètement optimisé 

SMOOTHIE CREATIVE

WP-SPREAD.COM

Problématiques

Travailler en équipe sur un projet sans conflits

Devoir réecrire un code similaire sur plusieurs projets

Tâches similaires récurrentes non automatisées

Projets de plus en plus complexes

Objectifs du process

 

Automatiser & réutiliser 

Gagner du temps

    - Lors de la mise en place du projet

    - Pendant le développement lui-même

Réutiliser sans recoder au maximum

Travailler sereinement en équipe

Eviter les erreurs humaines

Notre Process

WP-CLI pour la mise en place du projet en un clic

Utilisation d'un starter theme

Versionnement des projets avec Git

Préprocesseurs & Browser refreshing

Utilisation d'outils comme Emmet

Mise en ligne via Git ou FTP via Deploy

 

WP-CLI

Automatiser des tâches WP en ligne de commande

PréRequis

Sublime Text

éditeur de code

iTerm

console

Alfred

lanceur d'apps

Possibilités de WP-CLI

Télécharger WordPress

Télécharger et activer des thèmes, plugins

Installer et configurer WordPress

Créer, modifier ou supprimer des pages et articles

Modifier des options

Accéder à la base de données

Chercher des chaines et les remplacer

Exporter des données

Chercher des mises à jour

...

Exemples d'utilisation

Installer une nouvelle instance WordPress "from scratch"

(ce que l'on va voir aujourd'hui)

 

Vérifier les mises à jour de vos sites, à la manière du service Manage WP

 

Remplacer toutes les URL d'images locales (site.dev ou site:8888) par l'URL de production, à la manière de Velvet Blues URL (idéal pour thèmes premium)

 

...

Installer WP en 5 minutes

Pratique les premières fois, mais répétitif et long au bout du centième site

 

Beaucoup de tâches récurrentes à faire à

chaque fois manuellement pendant et

après l'installation

 

WP-CLI va nous permettre

d'automatiser cette tâche !

Listing des tâches

Créer une base de données dans phpMyAdmin

Créer un Alias Apache

Télécharger la dernière version FR de WordPress

Le placer dans votre dossier de travail

Installation en 5 minutes

  - indiquer les accès à la base

  - définir le nom du site, l'id et le mdp

Faire quelques réglages

Télécharger votre thème

L'activer

Télécharger vos plugins préférés

Les activer

Configurer votre thème et vos plugins

Définir la structure des permaliens (/%postname%/)

Supprimer Hello Dolly

Supprimer les thèmes twenty...

Supprimer les articles et pages de bases

Créer vos premières pages (Accueil, Actus, Contact...)

Créer votre menu principal

Assigner les pages à votre menu

Giter votre projet faire le premier commit

Ouvrir votre éditeur de code

Installer WP-CLI

Installation  (wp-cli.org/)

curl -O https://raw.githubusercontent.com/wp-cli/builds/gh-pages/phar/wp-cli.phar

Vérification

# FIX PHP MAMP for WP-CLI
export PATH=/Applications/MAMP/bin/php/php5.6.2/bin:$PATH
export PATH=$PATH:/Applications/MAMP/Library/bin/

Mamp : Ajouter des Paths pour pointer vers le bon PHP

php wp-cli.phar --info

A mettre dans le fichier .zshrc situé à la racine du système ~/.zshrc 

Notre Script BAsh

Nous avons réalisé un script Bash permettant d'automatiser toutes les tâches vues plus haut

 

Le script Bash est un fichier .sh qui peut être exécuté par un terminal via la commande suivante :

 

 

Le script bash nous permet d'accéder aux opérations système : créer un dossier, télécharger un fichier

et lancer les commandes WP-CLI

bash /path/to/myscript.sh argument1 argument2

Wippy
 

Wippy (。◕‿◕。) est notre script WP

Analysons le code Bash

Et ensuite nous lancerons une démo (amen)

Lancer le script via alfred

Il est possible de créer une action Alfred si vous possédez le PowerPack

Créer l'action Alfred

1. Définir un mot-clé

2. Action Terminal pour lancer le script bash

3. Notification système

1. Définir le mot clé

2. Lancer le script

{query} permet de récupérer les arguments

3. Notification OS

La démo !

themes

Starters / Blank / Frameworks / Selfmade

Starter themes

Thèmes de démarrage

 

Bones (http://themble.com/bones/)

Underscores (http://underscores.me/)

 

Frameworks

 

WooThemes Canvas (http://www.woothemes.com/products/canvas/)

Genesis (http://my.studiopress.com/themes/genesis/)

Thèmes "Nus"

 

Blank (http://html5blank.com/)

 

Votre propre starter theme ?

 

Nous utilisons notre propre thème, amélioré au fil des projets avec toutes les fonctionnalités de base dont on a besoin

 

WP 0 Theme (https://bitbucket.org/maximebj/wordpress-zero-theme)

Git

Versionner son projet et améliorer le flux de dév

Pourquoi versionner ?

Sauvegarde chaque étape de développement comme une sauvegarde dans un jeu vidéo

 

Travailler efficacement en équipe : fusion automatique des versions et aide à la résolution de conflits de code

 

Pousser en production en une commande

 

Partager facilement un projet Open Source

 

Wiki,  Gestion des bugs/erreurs ...

Comment versionner ?

En ligne de commande

 

Pour les plus téméraires

 

Avec une application

 

Tower for Mac (http://www.git-tower.com/)

Github for Mac et windows (https://mac.github.com/)

hébergeR son code

Github.com

Beanstalkapp.com

Bitbucket.com  (gratuit)

 

 

Aussi bien pour code open source que code privé

Préprocesseurs

Alléger l'écriture de votre HTML/CSS/JS

A quoi servent-ils ?

Ecrire moins de code

Lecture du code plus claire

Meilleure maintenabilité du code

DRY : Don't repeat yourself

Quelques prépocesseurs

CSS

Sass & Compass / Less / Stylus / Bourbon

 

JS

CoffeeScript

 

HTML 

Haml

Exemples

Stylus

HAML

Quelles technos ?

Les préprocesseurs ont besoin d'être compilés à l'enregistrement pour devenir du js, html et css purs

 

La méthode brute

Grunt (http://gruntjs.com/)

 

La méthode douce

Codekit for Mac (https://incident57.com/codekit/)

Codekit

Compilation automatique de tous vos fichiers

Minification automatique

Vérification de votre code JS (JSHint)

Ajout des préfixs CSS automatique : Autoprefixr

Rafraichissement de la page automatique sur tous vos périphériques

...

Browser Refresh

Mettre à jour vos navigateurs, sur desktop / mobile / tablette automatiquement lors de l'enregistrement d'un fichier du site

Emmet

anciennement zencoding

Coder moins avec Emmet

Écriture abrégée

Après appui sur Tab

Mise en ligne

Automatisée pour gagner du temps et limiter les erreurs

Déploiement

Eviter une mise en ligne "à la main" pour éviter les erreurs

 

Vous pourrez pousser en ligne avec Git. Nous utilisons WP Engine pour héberger nos sites et nous pouvons "pousser" une version d'un clic en préprod ou prod

 

Déploiement rapide via FTP avec Dploy en nodejs

(https://github.com/LeanMeanFightingMachine/dploy)

Bien OrganisÉ

Gérer efficacement les projets, tâches,

travailler à distance en équipe ...

Bonus

Trello

Merci !

 

 

@maximebj

 

Mon blog : wp-spread.com

Notre agence web : smoothie-creative.com

 

 

Illustrations : https://dribbble.com/buatoom