SlideShare a Scribd company logo
A Custom Drupal Theme in 40 35 minutes
DRUPALGOVCON 2016
Daniel Schiavone
Starting point
Drupal 8 installed
Debugging enabled
Sample content
Modules - Devel, Display Suite, Responsive Image
Development Environment
Disable cache, Enable Twig debug
Templates → /modules/system/templates
settings.php and settings.local.php
service.yml and development.services.yml
YAML
---
# Employee record
name: Joey
job: Themer
skills:
- Music
- Art
languages:
php: Elite
javascript: Elite
YAML is a human friendly data
serialization standard for all
programming languages.
(but not tab friendly)
http://www.yaml.org/
Twig
Print something
{{ name }}
Run code
{% set class = “something-something” %}
Comment
{# This is something #}
http://twig.sensiolabs.org/doc/templates.html
Sass
A CSS preprocessor that adds power and elegance to the basic language with use
variables, nested rules, mixins, inline imports, and more.
$font-stack: Helvetica, sans-serif;
$primary-color: #333;
body {
font: 100% $font-stack;
color: $primary-color;
}
http://sass-lang.com
body {
font: 100% Helvetica,
sans-serif;
color: #333;
}
Options for Creating a Theme
● From scratch (by default themes use Stable as Base Theme)
● Contrib theme
● Subtheme
○ Core base themes
■ Classy - base theme for Bartik and Seven
■ Stable - bare minimum/style for things to work
○ Other base themes
Classy vs Stable
<div class="field field--name-field-time-
lord field--type-string field--label-
above">
<div class="field__label">Time
Lords</div>
<div class='field__items'>
<div class="field__item">The Doctor
</div>
<div class="field__item">River
Song</div>
</div>
</div>
<div>
<div>Time Lords</div>
<div>
<div>The Doctor</div>
<div>River Song</div>
</div>
</div>
Anatomy of a Theme
mytheme.info.yml
mytheme.libraries.yml
mytheme.breakpoints.yml
mytheme
css
scss
styles.scss
images
templates
js
lib
Ready, set, go!
Resources - Development Environment
● Local environment - LAMP/MAMP, Acquia DevDesktop
● Browser extensions - Firebug, Livereload
http://www.acquia.com/downloads
http://getfirebug.com
http://livereload.com/extensions
● Gulp → https://css-tricks.com/gulp-for-beginners
Resources - Drush & Gulp
● In order to use Drush with Drupal 8 you need composer
● Windows → https://modulesunraveled.com/drush/installing-
drush-windows
● Mac → https://www.drupal.org/node/1674222
● Linux → http://whaaat.com/installing-drush-8-using-composer
https://www.drupal.org/node/1791676
● Gulp → https://css-tricks.com/gulp-for-beginners
Resources - Development
Acquia Dev Desktop → http://www.acquia.com/downloads
Firebug → http://getfirebug.com
Livereload → http://livereload.com/extensions
Resources - Learn
@MortenDK’s Barcelona Session
https://www.youtube.com/watch?v=1m6WR7e7qwU
Watch and Learn YouTube Channel https://www.youtube.
com/channel/UCXQC_GB5hG6PkzIhSMZ-hWA
Notes from my Designing with Drupal 8 course
http://www.SnakeHill.net/designingd8
Meetups, Camps and Cons
Questions
Daniel Schiavone
www.SnakeHill.net
Daniel@SnakeHill.net
@schiavo
@Snake_Hill
DDO: schiavone
Community
Drupal Global Training Day → Sept 9, 10, 2016
Baltimore DrupalCamp → Oct 7, 2016
DrupaCon Baltimore!!! → April 24 - 27, 2017
Baltimore Drupal Meetup → 2nd Wed @ Bertha’s
meetup.com/Baltimore-Drupal-Meetup
Baltimore / DC Drupal Co-working
A Custom Drupal Theme in 40 Minutes

More Related Content

What's hot (20)

ODP
Drupal distributions - how to build them
Dick Olsson
 
PPTX
Display Suite: A Themers Perspective
Mediacurrent
 
PPTX
WordPress Themes and Plugins
superann
 
PDF
WordPress Theme Development Basics
Tech Liminal
 
PDF
WordPress Theme Workshop: Part 0
David Bisset
 
PDF
Introduction to the Drupal - Web Experience Toolkit
Suzanne Dergacheva
 
PDF
WordPress Theme Workshop: Part 1
David Bisset
 
PDF
Battle of the Front-End Frameworks: Bootstrap vs. Foundation
Rachel Cherry
 
PPTX
Web 101 intro to html
Hawkman Academy
 
PDF
The Wonderful World of Drupal 8 Multilingual
Suzanne Dergacheva
 
PPTX
Word press bootcamp By Sourcescript Innovations and Mentors Dojo
lightshire
 
KEY
Getting started with CSS frameworks using Zurb foundation
Melanie Archer
 
PPTX
Wordpress theme development
Naeem Junejo
 
PDF
Creating a Drupal Install Profile for a Large Organization
Suzanne Dergacheva
 
PDF
Creating Landing Pages and Layouts for Drupal 8 - DrupalCon Baltimore
Suzanne Dergacheva
 
PDF
DrupalCamp NYC Panels Presentation - April 2014
Suzanne Dergacheva
 
PPTX
Design todevelop
Jason Yingling
 
PDF
Zurb foundation
sean_todd
 
PDF
What is Drupal? And Why is it Useful? Webinar
Suzanne Dergacheva
 
PPTX
WordPress Theme Development
Santosh Kunwar
 
Drupal distributions - how to build them
Dick Olsson
 
Display Suite: A Themers Perspective
Mediacurrent
 
WordPress Themes and Plugins
superann
 
WordPress Theme Development Basics
Tech Liminal
 
WordPress Theme Workshop: Part 0
David Bisset
 
Introduction to the Drupal - Web Experience Toolkit
Suzanne Dergacheva
 
WordPress Theme Workshop: Part 1
David Bisset
 
Battle of the Front-End Frameworks: Bootstrap vs. Foundation
Rachel Cherry
 
Web 101 intro to html
Hawkman Academy
 
The Wonderful World of Drupal 8 Multilingual
Suzanne Dergacheva
 
Word press bootcamp By Sourcescript Innovations and Mentors Dojo
lightshire
 
Getting started with CSS frameworks using Zurb foundation
Melanie Archer
 
Wordpress theme development
Naeem Junejo
 
Creating a Drupal Install Profile for a Large Organization
Suzanne Dergacheva
 
Creating Landing Pages and Layouts for Drupal 8 - DrupalCon Baltimore
Suzanne Dergacheva
 
DrupalCamp NYC Panels Presentation - April 2014
Suzanne Dergacheva
 
Design todevelop
Jason Yingling
 
Zurb foundation
sean_todd
 
What is Drupal? And Why is it Useful? Webinar
Suzanne Dergacheva
 
WordPress Theme Development
Santosh Kunwar
 

Viewers also liked (10)

PDF
UX design for every screen
Four Kitchens
 
ZIP
Theme Kickstart
Peter
 
PDF
[Srijan Wednesday Webinars] Drupal 8: Goodbye to 10 Years of Theming Headaches
Srijan Technologies
 
PPT
PSD to a Drupal Theme (using a base theme)
kuydigital
 
PPT
Converting Static Html To Drupal Theme
Ryan Cross
 
PDF
Building a Custom Theme in Drupal 8
Anne Tomasevich
 
PPTX
Connected Health Reference Architecture
WSO2
 
PDF
A Reference Architecture for ETL 2.0
DataWorks Summit
 
PDF
What is personal connected health?
Personal Connected Health Alliance
 
PPTX
Best Practices for the Hadoop Data Warehouse: EDW 101 for Hadoop Professionals
Cloudera, Inc.
 
UX design for every screen
Four Kitchens
 
Theme Kickstart
Peter
 
[Srijan Wednesday Webinars] Drupal 8: Goodbye to 10 Years of Theming Headaches
Srijan Technologies
 
PSD to a Drupal Theme (using a base theme)
kuydigital
 
Converting Static Html To Drupal Theme
Ryan Cross
 
Building a Custom Theme in Drupal 8
Anne Tomasevich
 
Connected Health Reference Architecture
WSO2
 
A Reference Architecture for ETL 2.0
DataWorks Summit
 
What is personal connected health?
Personal Connected Health Alliance
 
Best Practices for the Hadoop Data Warehouse: EDW 101 for Hadoop Professionals
Cloudera, Inc.
 
Ad

Similar to A Custom Drupal Theme in 40 Minutes (20)

PDF
Designing with Drupal 8
Snake Hill Web Agency
 
PDF
Drupal 8: frontend development
sparkfabrik
 
PPTX
Ready. Set. Drupal! An Intro to Drupal 8, Part 2
Acquia
 
ODP
DrupalEasy: Intro to Theme Development
ultimike
 
PDF
Drupal 8 - Corso frontend development
sparkfabrik
 
PDF
Drupal Theming An Introduction
Lauren Roth
 
PDF
Let's Zen! (Stop Theming From Scratch)
Chris Charlton
 
PDF
Drupal 8 theming deep dive
Romain Jarraud
 
PDF
Building your first d8 theme
Mario Hernandez
 
PPTX
Drupalcamp Atlanta 2010 Design-to-Theme
Mediacurrent
 
PDF
Evaluating Base Themes
Emma Jane Hogbin Westby
 
PPTX
Drupal Theming For Beginners – Danté SELF 2010
Mediacurrent
 
ODP
Drupal Theme Development - DrupalCon Chicago 2011
Ryan Price
 
PDF
Drupaldelphia Shortcuts Cheats And Cheap Stunts
canarymason
 
PDF
Drupal 8 theming principles
DrupalCamp Kyiv Рысь
 
PDF
Drupal 8 theming principles
Kirill Borzov
 
PDF
Forensic Theming - DrupalCon London
Emma Jane Hogbin Westby
 
PPTX
Atlanta Drupal User Group (ADUG)
Mediacurrent
 
PDF
Drupal theming training
dropsolid
 
PDF
Death of a Themer
James Panton
 
Designing with Drupal 8
Snake Hill Web Agency
 
Drupal 8: frontend development
sparkfabrik
 
Ready. Set. Drupal! An Intro to Drupal 8, Part 2
Acquia
 
DrupalEasy: Intro to Theme Development
ultimike
 
Drupal 8 - Corso frontend development
sparkfabrik
 
Drupal Theming An Introduction
Lauren Roth
 
Let's Zen! (Stop Theming From Scratch)
Chris Charlton
 
Drupal 8 theming deep dive
Romain Jarraud
 
Building your first d8 theme
Mario Hernandez
 
Drupalcamp Atlanta 2010 Design-to-Theme
Mediacurrent
 
Evaluating Base Themes
Emma Jane Hogbin Westby
 
Drupal Theming For Beginners – Danté SELF 2010
Mediacurrent
 
Drupal Theme Development - DrupalCon Chicago 2011
Ryan Price
 
Drupaldelphia Shortcuts Cheats And Cheap Stunts
canarymason
 
Drupal 8 theming principles
DrupalCamp Kyiv Рысь
 
Drupal 8 theming principles
Kirill Borzov
 
Forensic Theming - DrupalCon London
Emma Jane Hogbin Westby
 
Atlanta Drupal User Group (ADUG)
Mediacurrent
 
Drupal theming training
dropsolid
 
Death of a Themer
James Panton
 
Ad

More from Snake Hill Web Agency (8)

PDF
Analyzing the Market for Drupal - Baltimore DrupalCamp 2018
Snake Hill Web Agency
 
PDF
4 Essential Checklist to Manage Drupal Projects
Snake Hill Web Agency
 
PPTX
Techniques for Designing with Drupal 8
Snake Hill Web Agency
 
PDF
Techniques for Designing with Drupal 8
Snake Hill Web Agency
 
PDF
Drupal Upgrade Decision Tree
Snake Hill Web Agency
 
ODP
The Ultimate Drupal Launch Checklist
Snake Hill Web Agency
 
ODP
10 Steps Not To Forget After Installing Drupal
Snake Hill Web Agency
 
PDF
Drupal 101
Snake Hill Web Agency
 
Analyzing the Market for Drupal - Baltimore DrupalCamp 2018
Snake Hill Web Agency
 
4 Essential Checklist to Manage Drupal Projects
Snake Hill Web Agency
 
Techniques for Designing with Drupal 8
Snake Hill Web Agency
 
Techniques for Designing with Drupal 8
Snake Hill Web Agency
 
Drupal Upgrade Decision Tree
Snake Hill Web Agency
 
The Ultimate Drupal Launch Checklist
Snake Hill Web Agency
 
10 Steps Not To Forget After Installing Drupal
Snake Hill Web Agency
 

Recently uploaded (20)

PPTX
OA presentation.pptx OA presentation.pptx
pateldhruv002338
 
PDF
Researching The Best Chat SDK Providers in 2025
Ray Fields
 
PDF
Responsible AI and AI Ethics - By Sylvester Ebhonu
Sylvester Ebhonu
 
PPTX
The Future of AI & Machine Learning.pptx
pritsen4700
 
PDF
Tea4chat - another LLM Project by Kerem Atam
a0m0rajab1
 
PDF
CIFDAQ's Market Wrap : Bears Back in Control?
CIFDAQ
 
PDF
NewMind AI Weekly Chronicles – July’25, Week III
NewMind AI
 
PPTX
Agile Chennai 18-19 July 2025 | Emerging patterns in Agentic AI by Bharani Su...
AgileNetwork
 
PDF
How ETL Control Logic Keeps Your Pipelines Safe and Reliable.pdf
Stryv Solutions Pvt. Ltd.
 
PPTX
AI and Robotics for Human Well-being.pptx
JAYMIN SUTHAR
 
PDF
MASTERDECK GRAPHSUMMIT SYDNEY (Public).pdf
Neo4j
 
PDF
GDG Cloud Munich - Intro - Luiz Carneiro - #BuildWithAI - July - Abdel.pdf
Luiz Carneiro
 
PDF
Trying to figure out MCP by actually building an app from scratch with open s...
Julien SIMON
 
PPTX
Agentic AI in Healthcare Driving the Next Wave of Digital Transformation
danielle hunter
 
PDF
Market Insight : ETH Dominance Returns
CIFDAQ
 
PPTX
Agile Chennai 18-19 July 2025 | Workshop - Enhancing Agile Collaboration with...
AgileNetwork
 
PDF
Brief History of Internet - Early Days of Internet
sutharharshit158
 
PDF
Presentation about Hardware and Software in Computer
snehamodhawadiya
 
PDF
OFFOFFBOX™ – A New Era for African Film | Startup Presentation
ambaicciwalkerbrian
 
PDF
A Strategic Analysis of the MVNO Wave in Emerging Markets.pdf
IPLOOK Networks
 
OA presentation.pptx OA presentation.pptx
pateldhruv002338
 
Researching The Best Chat SDK Providers in 2025
Ray Fields
 
Responsible AI and AI Ethics - By Sylvester Ebhonu
Sylvester Ebhonu
 
The Future of AI & Machine Learning.pptx
pritsen4700
 
Tea4chat - another LLM Project by Kerem Atam
a0m0rajab1
 
CIFDAQ's Market Wrap : Bears Back in Control?
CIFDAQ
 
NewMind AI Weekly Chronicles – July’25, Week III
NewMind AI
 
Agile Chennai 18-19 July 2025 | Emerging patterns in Agentic AI by Bharani Su...
AgileNetwork
 
How ETL Control Logic Keeps Your Pipelines Safe and Reliable.pdf
Stryv Solutions Pvt. Ltd.
 
AI and Robotics for Human Well-being.pptx
JAYMIN SUTHAR
 
MASTERDECK GRAPHSUMMIT SYDNEY (Public).pdf
Neo4j
 
GDG Cloud Munich - Intro - Luiz Carneiro - #BuildWithAI - July - Abdel.pdf
Luiz Carneiro
 
Trying to figure out MCP by actually building an app from scratch with open s...
Julien SIMON
 
Agentic AI in Healthcare Driving the Next Wave of Digital Transformation
danielle hunter
 
Market Insight : ETH Dominance Returns
CIFDAQ
 
Agile Chennai 18-19 July 2025 | Workshop - Enhancing Agile Collaboration with...
AgileNetwork
 
Brief History of Internet - Early Days of Internet
sutharharshit158
 
Presentation about Hardware and Software in Computer
snehamodhawadiya
 
OFFOFFBOX™ – A New Era for African Film | Startup Presentation
ambaicciwalkerbrian
 
A Strategic Analysis of the MVNO Wave in Emerging Markets.pdf
IPLOOK Networks
 

A Custom Drupal Theme in 40 Minutes

  • 1. A Custom Drupal Theme in 40 35 minutes DRUPALGOVCON 2016 Daniel Schiavone
  • 2. Starting point Drupal 8 installed Debugging enabled Sample content Modules - Devel, Display Suite, Responsive Image
  • 3. Development Environment Disable cache, Enable Twig debug Templates → /modules/system/templates settings.php and settings.local.php service.yml and development.services.yml
  • 4. YAML --- # Employee record name: Joey job: Themer skills: - Music - Art languages: php: Elite javascript: Elite YAML is a human friendly data serialization standard for all programming languages. (but not tab friendly) http://www.yaml.org/
  • 5. Twig Print something {{ name }} Run code {% set class = “something-something” %} Comment {# This is something #} http://twig.sensiolabs.org/doc/templates.html
  • 6. Sass A CSS preprocessor that adds power and elegance to the basic language with use variables, nested rules, mixins, inline imports, and more. $font-stack: Helvetica, sans-serif; $primary-color: #333; body { font: 100% $font-stack; color: $primary-color; } http://sass-lang.com body { font: 100% Helvetica, sans-serif; color: #333; }
  • 7. Options for Creating a Theme ● From scratch (by default themes use Stable as Base Theme) ● Contrib theme ● Subtheme ○ Core base themes ■ Classy - base theme for Bartik and Seven ■ Stable - bare minimum/style for things to work ○ Other base themes
  • 8. Classy vs Stable <div class="field field--name-field-time- lord field--type-string field--label- above"> <div class="field__label">Time Lords</div> <div class='field__items'> <div class="field__item">The Doctor </div> <div class="field__item">River Song</div> </div> </div> <div> <div>Time Lords</div> <div> <div>The Doctor</div> <div>River Song</div> </div> </div>
  • 9. Anatomy of a Theme mytheme.info.yml mytheme.libraries.yml mytheme.breakpoints.yml mytheme css scss styles.scss images templates js lib
  • 11. Resources - Development Environment ● Local environment - LAMP/MAMP, Acquia DevDesktop ● Browser extensions - Firebug, Livereload http://www.acquia.com/downloads http://getfirebug.com http://livereload.com/extensions ● Gulp → https://css-tricks.com/gulp-for-beginners
  • 12. Resources - Drush & Gulp ● In order to use Drush with Drupal 8 you need composer ● Windows → https://modulesunraveled.com/drush/installing- drush-windows ● Mac → https://www.drupal.org/node/1674222 ● Linux → http://whaaat.com/installing-drush-8-using-composer https://www.drupal.org/node/1791676 ● Gulp → https://css-tricks.com/gulp-for-beginners
  • 13. Resources - Development Acquia Dev Desktop → http://www.acquia.com/downloads Firebug → http://getfirebug.com Livereload → http://livereload.com/extensions
  • 14. Resources - Learn @MortenDK’s Barcelona Session https://www.youtube.com/watch?v=1m6WR7e7qwU Watch and Learn YouTube Channel https://www.youtube. com/channel/UCXQC_GB5hG6PkzIhSMZ-hWA Notes from my Designing with Drupal 8 course http://www.SnakeHill.net/designingd8 Meetups, Camps and Cons
  • 15. Questions Daniel Schiavone www.SnakeHill.net [email protected] @schiavo @Snake_Hill DDO: schiavone Community Drupal Global Training Day → Sept 9, 10, 2016 Baltimore DrupalCamp → Oct 7, 2016 DrupaCon Baltimore!!! → April 24 - 27, 2017 Baltimore Drupal Meetup → 2nd Wed @ Bertha’s meetup.com/Baltimore-Drupal-Meetup Baltimore / DC Drupal Co-working