SlideShare une entreprise Scribd logo
1  sur  17
Télécharger pour lire hors ligne
Please use Compass/Sass for Themes
If I may… And other whys answered.
!
!
by Chris Charlton http://xtnd.us
For & Against
2
Preaching to the choir here.
Arguments For
‣ Write and maintain less code.
‣ Easily generate aesthetically pleasing color schemes.
‣ Wonderful, easy support for bitmap & vector graphics.
‣ Be dynamic and responsive (not in the mobile sense).
‣ Evolve.
3
You’re that guy.
Arguments Against
‣ “It’s just another thing to learn.”
‣ “What’s wrong with regular CSS?”
‣ “What if the user doesn’t know Sass?”
‣ “It was trouble to get PHP running, now I need Ruby?!”
‣ “Sass has too many files. One CSS file is all I need!”
4
For
5
Even your first Sass theme will feel good. Imagine you, but 2.0
Write less code
‣ Nesting, Variables, Mixins, [stupid] Vendor prefixes, etc.
‣ Sub-themes and variants are tiny.
‣ CSS output control; scrubbed, minified, and compressed.
‣ New modular styles answer where to organize things.
6
7
$white : #FFFFFF;	
$light : #EEEEEE;	
$dark : #666666;
8
theme/layout/grid.scss	
theme/modules/buttons.scss	
theme/modules/callouts.scss	
theme/base.scss
Don’t let programmers choose colors.
Color
// Sass	
mix(...); // Mix two colors	
complement(...); // Complementary	
invert(...); // Invert color	
// Compass	
shade(...); // Darken	
tint(...); // Lighten	
contrasted(...); // Smart	
// “compass-colors” gem provides more	
9
It’s “mind bottling.”
Great bitmap & vector graphics support
‣ Auto-generate Image Sprites from image folders
‣ Leverage dynamic vector and graphic functions.
‣ Leverage CSS3 effects & graphics capabilities
• shapes, masks, rounded corners, shadows, glows, gradients
10
11
.element {	
// Find image by name	
background-image: image-url("icon.png");	
}
12
$image: url("images/example.png");	
!
.element {	
// No need to hardcode image sizes	
height: image-height($image);	
}
13
// Output green spritesheet + classes	
@import "images/green/*.png";	
@include all-green-sprites;	
!
!
// Output blue spritesheet	
@import "images/blue/*.png";	
!
.element {	
@include background(blue-sprite(icon));	
height: blue-sprite-height(icon);	
width: blue-sprite-width(icon);	
}
True Sass Ninjas cuts three columns in one swipe.
Be dynamic! (Responsive is in next slide)
‣ Conditional logic for dynamic column styles.
‣ Centralizing colors (and images) makes for easier, and
better customization. Maintenance profit.
‣ Leverage Sass mixins & functions to reproduce graphics
to eliminate shipping with resolution-limited bitmaps.
‣ CSS3 animations & transformations bring themes alive!
14
Mobile - BOOM!
Now be RESPONSIVE
‣ This is your next frontier when done with Sass basics.
‣ Good excuse to buy that tablet or any other device.
‣ Motivation to use SVG along with PNG.
15
CSS3 - BOOM!
Build on top of CSS3
‣ This is the new frontier in standards compliance.
‣ Another good excuse to buy that new tablet/device.
‣ Another excuse to use SVG along with PNG.
16
Fin
17

Contenu connexe

En vedette

A construcao do_modelo_de_capacitacao_do_gestor_publico_estrategico_do_espiri...
A construcao do_modelo_de_capacitacao_do_gestor_publico_estrategico_do_espiri...A construcao do_modelo_de_capacitacao_do_gestor_publico_estrategico_do_espiri...
A construcao do_modelo_de_capacitacao_do_gestor_publico_estrategico_do_espiri...Tania Madeira
 
Bellbird. Pájaro campana
Bellbird. Pájaro campanaBellbird. Pájaro campana
Bellbird. Pájaro campanaCachi Chien
 
5 langkah mengubah ide menjadi sebuah produk
5 langkah mengubah ide menjadi sebuah produk5 langkah mengubah ide menjadi sebuah produk
5 langkah mengubah ide menjadi sebuah produkPoteng Kayu
 
(Webinar) Unlocking Mobile Conversions - Featuring Guest Presenter Charles Ni...
(Webinar) Unlocking Mobile Conversions - Featuring Guest Presenter Charles Ni...(Webinar) Unlocking Mobile Conversions - Featuring Guest Presenter Charles Ni...
(Webinar) Unlocking Mobile Conversions - Featuring Guest Presenter Charles Ni...SiteTuners Conversion Rate Optimization
 
Tema 5 -_as_-_modelacao_do_fluxo_de_dados_-_dc_dfd_2009
Tema 5 -_as_-_modelacao_do_fluxo_de_dados_-_dc_dfd_2009Tema 5 -_as_-_modelacao_do_fluxo_de_dados_-_dc_dfd_2009
Tema 5 -_as_-_modelacao_do_fluxo_de_dados_-_dc_dfd_2009Pedro A. Uamusse
 
De kracht van gamification #DML12
De kracht van gamification #DML12De kracht van gamification #DML12
De kracht van gamification #DML12Fanminds
 
Lesson 1. range of connectives
Lesson 1. range of connectivesLesson 1. range of connectives
Lesson 1. range of connectivespgslearning
 
Pinturas terremoto.Earthquake paintings (Japón 1923)
Pinturas terremoto.Earthquake paintings (Japón 1923)Pinturas terremoto.Earthquake paintings (Japón 1923)
Pinturas terremoto.Earthquake paintings (Japón 1923)Cachi Chien
 
Sugestoes ferramentas
Sugestoes ferramentasSugestoes ferramentas
Sugestoes ferramentasMarli Regis
 
архитектура построение и перспектива рисунка
архитектура построение и перспектива рисункаархитектура построение и перспектива рисунка
архитектура построение и перспектива рисункаДенис Семыкин
 
endovascular.es Newsletter i:2012
endovascular.es Newsletter i:2012endovascular.es Newsletter i:2012
endovascular.es Newsletter i:2012Salutaria
 
Charla lectura carmen najera
Charla lectura carmen najeraCharla lectura carmen najera
Charla lectura carmen najerainstitutodeolvega
 

En vedette (18)

The family
The familyThe family
The family
 
A construcao do_modelo_de_capacitacao_do_gestor_publico_estrategico_do_espiri...
A construcao do_modelo_de_capacitacao_do_gestor_publico_estrategico_do_espiri...A construcao do_modelo_de_capacitacao_do_gestor_publico_estrategico_do_espiri...
A construcao do_modelo_de_capacitacao_do_gestor_publico_estrategico_do_espiri...
 
Mar
MarMar
Mar
 
Bellbird. Pájaro campana
Bellbird. Pájaro campanaBellbird. Pájaro campana
Bellbird. Pájaro campana
 
5 langkah mengubah ide menjadi sebuah produk
5 langkah mengubah ide menjadi sebuah produk5 langkah mengubah ide menjadi sebuah produk
5 langkah mengubah ide menjadi sebuah produk
 
Guia del participante
Guia del participanteGuia del participante
Guia del participante
 
Acesso pc
Acesso pcAcesso pc
Acesso pc
 
(Webinar) Unlocking Mobile Conversions - Featuring Guest Presenter Charles Ni...
(Webinar) Unlocking Mobile Conversions - Featuring Guest Presenter Charles Ni...(Webinar) Unlocking Mobile Conversions - Featuring Guest Presenter Charles Ni...
(Webinar) Unlocking Mobile Conversions - Featuring Guest Presenter Charles Ni...
 
Tema 5 -_as_-_modelacao_do_fluxo_de_dados_-_dc_dfd_2009
Tema 5 -_as_-_modelacao_do_fluxo_de_dados_-_dc_dfd_2009Tema 5 -_as_-_modelacao_do_fluxo_de_dados_-_dc_dfd_2009
Tema 5 -_as_-_modelacao_do_fluxo_de_dados_-_dc_dfd_2009
 
Changes to JHSC Certification Training
Changes to JHSC Certification TrainingChanges to JHSC Certification Training
Changes to JHSC Certification Training
 
De kracht van gamification #DML12
De kracht van gamification #DML12De kracht van gamification #DML12
De kracht van gamification #DML12
 
Lesson 1. range of connectives
Lesson 1. range of connectivesLesson 1. range of connectives
Lesson 1. range of connectives
 
Pinturas terremoto.Earthquake paintings (Japón 1923)
Pinturas terremoto.Earthquake paintings (Japón 1923)Pinturas terremoto.Earthquake paintings (Japón 1923)
Pinturas terremoto.Earthquake paintings (Japón 1923)
 
Sugestoes ferramentas
Sugestoes ferramentasSugestoes ferramentas
Sugestoes ferramentas
 
архитектура построение и перспектива рисунка
архитектура построение и перспектива рисункаархитектура построение и перспектива рисунка
архитектура построение и перспектива рисунка
 
endovascular.es Newsletter i:2012
endovascular.es Newsletter i:2012endovascular.es Newsletter i:2012
endovascular.es Newsletter i:2012
 
Charla lectura carmen najera
Charla lectura carmen najeraCharla lectura carmen najera
Charla lectura carmen najera
 
Comunicación política para gremialistas
Comunicación política para gremialistasComunicación política para gremialistas
Comunicación política para gremialistas
 

Plus de Chris Charlton

Drupal Form API 101 (PHP) - DrupalCamp LA 2012
Drupal Form API 101 (PHP) - DrupalCamp LA 2012Drupal Form API 101 (PHP) - DrupalCamp LA 2012
Drupal Form API 101 (PHP) - DrupalCamp LA 2012Chris Charlton
 
Drupal Developer Skills (2012) - DrupalCamp LA 2012
Drupal Developer Skills (2012) - DrupalCamp LA 2012Drupal Developer Skills (2012) - DrupalCamp LA 2012
Drupal Developer Skills (2012) - DrupalCamp LA 2012Chris Charlton
 
Sassy CSS (part 2) (Drupal Camp LA 2013)
Sassy CSS (part 2) (Drupal Camp LA 2013)Sassy CSS (part 2) (Drupal Camp LA 2013)
Sassy CSS (part 2) (Drupal Camp LA 2013)Chris Charlton
 
Lightning Talk: Drush aliases (Drupal Camp LA 2013)
Lightning Talk: Drush aliases (Drupal Camp LA 2013)Lightning Talk: Drush aliases (Drupal Camp LA 2013)
Lightning Talk: Drush aliases (Drupal Camp LA 2013)Chris Charlton
 
Site Aliases: Powerful Drupal Administration Using Drush by Chris Charlton
Site Aliases: Powerful Drupal Administration Using Drush by Chris CharltonSite Aliases: Powerful Drupal Administration Using Drush by Chris Charlton
Site Aliases: Powerful Drupal Administration Using Drush by Chris CharltonChris Charlton
 
Policy File: Powerful Drupal Administration Using Drush
Policy File: Powerful Drupal Administration Using DrushPolicy File: Powerful Drupal Administration Using Drush
Policy File: Powerful Drupal Administration Using DrushChris Charlton
 
Drush 5.0 (DrupalCamp LA 2012) - Chris Charlton
Drush 5.0 (DrupalCamp LA 2012) - Chris CharltonDrush 5.0 (DrupalCamp LA 2012) - Chris Charlton
Drush 5.0 (DrupalCamp LA 2012) - Chris CharltonChris Charlton
 
Changes to Drupal Themes in version 7 (part 1)
Changes to Drupal Themes in version 7 (part 1)Changes to Drupal Themes in version 7 (part 1)
Changes to Drupal Themes in version 7 (part 1)Chris Charlton
 
Web Content Management Systems From A Designer's Perspective (Drupal Technica...
Web Content Management Systems From A Designer's Perspective (Drupal Technica...Web Content Management Systems From A Designer's Perspective (Drupal Technica...
Web Content Management Systems From A Designer's Perspective (Drupal Technica...Chris Charlton
 
Let's Zen! (Stop Theming From Scratch)
Let's Zen! (Stop Theming From Scratch)Let's Zen! (Stop Theming From Scratch)
Let's Zen! (Stop Theming From Scratch)Chris Charlton
 
Flex Flash Air Interfaces for Custom Content Types in Drupal Chris Charlton
Flex Flash Air Interfaces for Custom Content Types in Drupal   Chris CharltonFlex Flash Air Interfaces for Custom Content Types in Drupal   Chris Charlton
Flex Flash Air Interfaces for Custom Content Types in Drupal Chris CharltonChris Charlton
 
Better Drupal Interaction Design with Flex
Better Drupal Interaction Design with FlexBetter Drupal Interaction Design with Flex
Better Drupal Interaction Design with FlexChris Charlton
 

Plus de Chris Charlton (12)

Drupal Form API 101 (PHP) - DrupalCamp LA 2012
Drupal Form API 101 (PHP) - DrupalCamp LA 2012Drupal Form API 101 (PHP) - DrupalCamp LA 2012
Drupal Form API 101 (PHP) - DrupalCamp LA 2012
 
Drupal Developer Skills (2012) - DrupalCamp LA 2012
Drupal Developer Skills (2012) - DrupalCamp LA 2012Drupal Developer Skills (2012) - DrupalCamp LA 2012
Drupal Developer Skills (2012) - DrupalCamp LA 2012
 
Sassy CSS (part 2) (Drupal Camp LA 2013)
Sassy CSS (part 2) (Drupal Camp LA 2013)Sassy CSS (part 2) (Drupal Camp LA 2013)
Sassy CSS (part 2) (Drupal Camp LA 2013)
 
Lightning Talk: Drush aliases (Drupal Camp LA 2013)
Lightning Talk: Drush aliases (Drupal Camp LA 2013)Lightning Talk: Drush aliases (Drupal Camp LA 2013)
Lightning Talk: Drush aliases (Drupal Camp LA 2013)
 
Site Aliases: Powerful Drupal Administration Using Drush by Chris Charlton
Site Aliases: Powerful Drupal Administration Using Drush by Chris CharltonSite Aliases: Powerful Drupal Administration Using Drush by Chris Charlton
Site Aliases: Powerful Drupal Administration Using Drush by Chris Charlton
 
Policy File: Powerful Drupal Administration Using Drush
Policy File: Powerful Drupal Administration Using DrushPolicy File: Powerful Drupal Administration Using Drush
Policy File: Powerful Drupal Administration Using Drush
 
Drush 5.0 (DrupalCamp LA 2012) - Chris Charlton
Drush 5.0 (DrupalCamp LA 2012) - Chris CharltonDrush 5.0 (DrupalCamp LA 2012) - Chris Charlton
Drush 5.0 (DrupalCamp LA 2012) - Chris Charlton
 
Changes to Drupal Themes in version 7 (part 1)
Changes to Drupal Themes in version 7 (part 1)Changes to Drupal Themes in version 7 (part 1)
Changes to Drupal Themes in version 7 (part 1)
 
Web Content Management Systems From A Designer's Perspective (Drupal Technica...
Web Content Management Systems From A Designer's Perspective (Drupal Technica...Web Content Management Systems From A Designer's Perspective (Drupal Technica...
Web Content Management Systems From A Designer's Perspective (Drupal Technica...
 
Let's Zen! (Stop Theming From Scratch)
Let's Zen! (Stop Theming From Scratch)Let's Zen! (Stop Theming From Scratch)
Let's Zen! (Stop Theming From Scratch)
 
Flex Flash Air Interfaces for Custom Content Types in Drupal Chris Charlton
Flex Flash Air Interfaces for Custom Content Types in Drupal   Chris CharltonFlex Flash Air Interfaces for Custom Content Types in Drupal   Chris Charlton
Flex Flash Air Interfaces for Custom Content Types in Drupal Chris Charlton
 
Better Drupal Interaction Design with Flex
Better Drupal Interaction Design with FlexBetter Drupal Interaction Design with Flex
Better Drupal Interaction Design with Flex
 

Dernier

WSO2Con204 - Hard Rock Presentation - Keynote
WSO2Con204 - Hard Rock Presentation - KeynoteWSO2Con204 - Hard Rock Presentation - Keynote
WSO2Con204 - Hard Rock Presentation - KeynoteWSO2
 
%+27788225528 love spells in Toronto Psychic Readings, Attraction spells,Brin...
%+27788225528 love spells in Toronto Psychic Readings, Attraction spells,Brin...%+27788225528 love spells in Toronto Psychic Readings, Attraction spells,Brin...
%+27788225528 love spells in Toronto Psychic Readings, Attraction spells,Brin...masabamasaba
 
VTU technical seminar 8Th Sem on Scikit-learn
VTU technical seminar 8Th Sem on Scikit-learnVTU technical seminar 8Th Sem on Scikit-learn
VTU technical seminar 8Th Sem on Scikit-learnAmarnathKambale
 
%in Soweto+277-882-255-28 abortion pills for sale in soweto
%in Soweto+277-882-255-28 abortion pills for sale in soweto%in Soweto+277-882-255-28 abortion pills for sale in soweto
%in Soweto+277-882-255-28 abortion pills for sale in sowetomasabamasaba
 
WSO2CON 2024 - Building the API First Enterprise – Running an API Program, fr...
WSO2CON 2024 - Building the API First Enterprise – Running an API Program, fr...WSO2CON 2024 - Building the API First Enterprise – Running an API Program, fr...
WSO2CON 2024 - Building the API First Enterprise – Running an API Program, fr...WSO2
 
Direct Style Effect Systems - The Print[A] Example - A Comprehension Aid
Direct Style Effect Systems -The Print[A] Example- A Comprehension AidDirect Style Effect Systems -The Print[A] Example- A Comprehension Aid
Direct Style Effect Systems - The Print[A] Example - A Comprehension AidPhilip Schwarz
 
Architecture decision records - How not to get lost in the past
Architecture decision records - How not to get lost in the pastArchitecture decision records - How not to get lost in the past
Architecture decision records - How not to get lost in the pastPapp Krisztián
 
WSO2CON 2024 - Cloud Native Middleware: Domain-Driven Design, Cell-Based Arch...
WSO2CON 2024 - Cloud Native Middleware: Domain-Driven Design, Cell-Based Arch...WSO2CON 2024 - Cloud Native Middleware: Domain-Driven Design, Cell-Based Arch...
WSO2CON 2024 - Cloud Native Middleware: Domain-Driven Design, Cell-Based Arch...WSO2
 
Announcing Codolex 2.0 from GDK Software
Announcing Codolex 2.0 from GDK SoftwareAnnouncing Codolex 2.0 from GDK Software
Announcing Codolex 2.0 from GDK SoftwareJim McKeeth
 
Devoxx UK 2024 - Going serverless with Quarkus, GraalVM native images and AWS...
Devoxx UK 2024 - Going serverless with Quarkus, GraalVM native images and AWS...Devoxx UK 2024 - Going serverless with Quarkus, GraalVM native images and AWS...
Devoxx UK 2024 - Going serverless with Quarkus, GraalVM native images and AWS...Bert Jan Schrijver
 
WSO2CON 2024 - Does Open Source Still Matter?
WSO2CON 2024 - Does Open Source Still Matter?WSO2CON 2024 - Does Open Source Still Matter?
WSO2CON 2024 - Does Open Source Still Matter?WSO2
 
WSO2CON 2024 - Navigating API Complexity: REST, GraphQL, gRPC, Websocket, Web...
WSO2CON 2024 - Navigating API Complexity: REST, GraphQL, gRPC, Websocket, Web...WSO2CON 2024 - Navigating API Complexity: REST, GraphQL, gRPC, Websocket, Web...
WSO2CON 2024 - Navigating API Complexity: REST, GraphQL, gRPC, Websocket, Web...WSO2
 
OpenChain - The Ramifications of ISO/IEC 5230 and ISO/IEC 18974 for Legal Pro...
OpenChain - The Ramifications of ISO/IEC 5230 and ISO/IEC 18974 for Legal Pro...OpenChain - The Ramifications of ISO/IEC 5230 and ISO/IEC 18974 for Legal Pro...
OpenChain - The Ramifications of ISO/IEC 5230 and ISO/IEC 18974 for Legal Pro...Shane Coughlan
 
%in Rustenburg+277-882-255-28 abortion pills for sale in Rustenburg
%in Rustenburg+277-882-255-28 abortion pills for sale in Rustenburg%in Rustenburg+277-882-255-28 abortion pills for sale in Rustenburg
%in Rustenburg+277-882-255-28 abortion pills for sale in Rustenburgmasabamasaba
 
%+27788225528 love spells in new york Psychic Readings, Attraction spells,Bri...
%+27788225528 love spells in new york Psychic Readings, Attraction spells,Bri...%+27788225528 love spells in new york Psychic Readings, Attraction spells,Bri...
%+27788225528 love spells in new york Psychic Readings, Attraction spells,Bri...masabamasaba
 
%in kempton park+277-882-255-28 abortion pills for sale in kempton park
%in kempton park+277-882-255-28 abortion pills for sale in kempton park %in kempton park+277-882-255-28 abortion pills for sale in kempton park
%in kempton park+277-882-255-28 abortion pills for sale in kempton park masabamasaba
 
WSO2CON 2024 - Freedom First—Unleashing Developer Potential with Open Source
WSO2CON 2024 - Freedom First—Unleashing Developer Potential with Open SourceWSO2CON 2024 - Freedom First—Unleashing Developer Potential with Open Source
WSO2CON 2024 - Freedom First—Unleashing Developer Potential with Open SourceWSO2
 
WSO2CON 2024 - How to Run a Security Program
WSO2CON 2024 - How to Run a Security ProgramWSO2CON 2024 - How to Run a Security Program
WSO2CON 2024 - How to Run a Security ProgramWSO2
 
%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...
%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...
%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...masabamasaba
 
WSO2Con2024 - Enabling Transactional System's Exponential Growth With Simplicity
WSO2Con2024 - Enabling Transactional System's Exponential Growth With SimplicityWSO2Con2024 - Enabling Transactional System's Exponential Growth With Simplicity
WSO2Con2024 - Enabling Transactional System's Exponential Growth With SimplicityWSO2
 

Dernier (20)

WSO2Con204 - Hard Rock Presentation - Keynote
WSO2Con204 - Hard Rock Presentation - KeynoteWSO2Con204 - Hard Rock Presentation - Keynote
WSO2Con204 - Hard Rock Presentation - Keynote
 
%+27788225528 love spells in Toronto Psychic Readings, Attraction spells,Brin...
%+27788225528 love spells in Toronto Psychic Readings, Attraction spells,Brin...%+27788225528 love spells in Toronto Psychic Readings, Attraction spells,Brin...
%+27788225528 love spells in Toronto Psychic Readings, Attraction spells,Brin...
 
VTU technical seminar 8Th Sem on Scikit-learn
VTU technical seminar 8Th Sem on Scikit-learnVTU technical seminar 8Th Sem on Scikit-learn
VTU technical seminar 8Th Sem on Scikit-learn
 
%in Soweto+277-882-255-28 abortion pills for sale in soweto
%in Soweto+277-882-255-28 abortion pills for sale in soweto%in Soweto+277-882-255-28 abortion pills for sale in soweto
%in Soweto+277-882-255-28 abortion pills for sale in soweto
 
WSO2CON 2024 - Building the API First Enterprise – Running an API Program, fr...
WSO2CON 2024 - Building the API First Enterprise – Running an API Program, fr...WSO2CON 2024 - Building the API First Enterprise – Running an API Program, fr...
WSO2CON 2024 - Building the API First Enterprise – Running an API Program, fr...
 
Direct Style Effect Systems - The Print[A] Example - A Comprehension Aid
Direct Style Effect Systems -The Print[A] Example- A Comprehension AidDirect Style Effect Systems -The Print[A] Example- A Comprehension Aid
Direct Style Effect Systems - The Print[A] Example - A Comprehension Aid
 
Architecture decision records - How not to get lost in the past
Architecture decision records - How not to get lost in the pastArchitecture decision records - How not to get lost in the past
Architecture decision records - How not to get lost in the past
 
WSO2CON 2024 - Cloud Native Middleware: Domain-Driven Design, Cell-Based Arch...
WSO2CON 2024 - Cloud Native Middleware: Domain-Driven Design, Cell-Based Arch...WSO2CON 2024 - Cloud Native Middleware: Domain-Driven Design, Cell-Based Arch...
WSO2CON 2024 - Cloud Native Middleware: Domain-Driven Design, Cell-Based Arch...
 
Announcing Codolex 2.0 from GDK Software
Announcing Codolex 2.0 from GDK SoftwareAnnouncing Codolex 2.0 from GDK Software
Announcing Codolex 2.0 from GDK Software
 
Devoxx UK 2024 - Going serverless with Quarkus, GraalVM native images and AWS...
Devoxx UK 2024 - Going serverless with Quarkus, GraalVM native images and AWS...Devoxx UK 2024 - Going serverless with Quarkus, GraalVM native images and AWS...
Devoxx UK 2024 - Going serverless with Quarkus, GraalVM native images and AWS...
 
WSO2CON 2024 - Does Open Source Still Matter?
WSO2CON 2024 - Does Open Source Still Matter?WSO2CON 2024 - Does Open Source Still Matter?
WSO2CON 2024 - Does Open Source Still Matter?
 
WSO2CON 2024 - Navigating API Complexity: REST, GraphQL, gRPC, Websocket, Web...
WSO2CON 2024 - Navigating API Complexity: REST, GraphQL, gRPC, Websocket, Web...WSO2CON 2024 - Navigating API Complexity: REST, GraphQL, gRPC, Websocket, Web...
WSO2CON 2024 - Navigating API Complexity: REST, GraphQL, gRPC, Websocket, Web...
 
OpenChain - The Ramifications of ISO/IEC 5230 and ISO/IEC 18974 for Legal Pro...
OpenChain - The Ramifications of ISO/IEC 5230 and ISO/IEC 18974 for Legal Pro...OpenChain - The Ramifications of ISO/IEC 5230 and ISO/IEC 18974 for Legal Pro...
OpenChain - The Ramifications of ISO/IEC 5230 and ISO/IEC 18974 for Legal Pro...
 
%in Rustenburg+277-882-255-28 abortion pills for sale in Rustenburg
%in Rustenburg+277-882-255-28 abortion pills for sale in Rustenburg%in Rustenburg+277-882-255-28 abortion pills for sale in Rustenburg
%in Rustenburg+277-882-255-28 abortion pills for sale in Rustenburg
 
%+27788225528 love spells in new york Psychic Readings, Attraction spells,Bri...
%+27788225528 love spells in new york Psychic Readings, Attraction spells,Bri...%+27788225528 love spells in new york Psychic Readings, Attraction spells,Bri...
%+27788225528 love spells in new york Psychic Readings, Attraction spells,Bri...
 
%in kempton park+277-882-255-28 abortion pills for sale in kempton park
%in kempton park+277-882-255-28 abortion pills for sale in kempton park %in kempton park+277-882-255-28 abortion pills for sale in kempton park
%in kempton park+277-882-255-28 abortion pills for sale in kempton park
 
WSO2CON 2024 - Freedom First—Unleashing Developer Potential with Open Source
WSO2CON 2024 - Freedom First—Unleashing Developer Potential with Open SourceWSO2CON 2024 - Freedom First—Unleashing Developer Potential with Open Source
WSO2CON 2024 - Freedom First—Unleashing Developer Potential with Open Source
 
WSO2CON 2024 - How to Run a Security Program
WSO2CON 2024 - How to Run a Security ProgramWSO2CON 2024 - How to Run a Security Program
WSO2CON 2024 - How to Run a Security Program
 
%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...
%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...
%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...
 
WSO2Con2024 - Enabling Transactional System's Exponential Growth With Simplicity
WSO2Con2024 - Enabling Transactional System's Exponential Growth With SimplicityWSO2Con2024 - Enabling Transactional System's Exponential Growth With Simplicity
WSO2Con2024 - Enabling Transactional System's Exponential Growth With Simplicity
 

Drupal Themes should use Compass (Drupal Camp LA 2013)

  • 1. Please use Compass/Sass for Themes If I may… And other whys answered. ! ! by Chris Charlton http://xtnd.us
  • 3. Preaching to the choir here. Arguments For ‣ Write and maintain less code. ‣ Easily generate aesthetically pleasing color schemes. ‣ Wonderful, easy support for bitmap & vector graphics. ‣ Be dynamic and responsive (not in the mobile sense). ‣ Evolve. 3
  • 4. You’re that guy. Arguments Against ‣ “It’s just another thing to learn.” ‣ “What’s wrong with regular CSS?” ‣ “What if the user doesn’t know Sass?” ‣ “It was trouble to get PHP running, now I need Ruby?!” ‣ “Sass has too many files. One CSS file is all I need!” 4
  • 6. Even your first Sass theme will feel good. Imagine you, but 2.0 Write less code ‣ Nesting, Variables, Mixins, [stupid] Vendor prefixes, etc. ‣ Sub-themes and variants are tiny. ‣ CSS output control; scrubbed, minified, and compressed. ‣ New modular styles answer where to organize things. 6
  • 7. 7 $white : #FFFFFF; $light : #EEEEEE; $dark : #666666;
  • 9. Don’t let programmers choose colors. Color // Sass mix(...); // Mix two colors complement(...); // Complementary invert(...); // Invert color // Compass shade(...); // Darken tint(...); // Lighten contrasted(...); // Smart // “compass-colors” gem provides more 9
  • 10. It’s “mind bottling.” Great bitmap & vector graphics support ‣ Auto-generate Image Sprites from image folders ‣ Leverage dynamic vector and graphic functions. ‣ Leverage CSS3 effects & graphics capabilities • shapes, masks, rounded corners, shadows, glows, gradients 10
  • 11. 11 .element { // Find image by name background-image: image-url("icon.png"); }
  • 12. 12 $image: url("images/example.png"); ! .element { // No need to hardcode image sizes height: image-height($image); }
  • 13. 13 // Output green spritesheet + classes @import "images/green/*.png"; @include all-green-sprites; ! ! // Output blue spritesheet @import "images/blue/*.png"; ! .element { @include background(blue-sprite(icon)); height: blue-sprite-height(icon); width: blue-sprite-width(icon); }
  • 14. True Sass Ninjas cuts three columns in one swipe. Be dynamic! (Responsive is in next slide) ‣ Conditional logic for dynamic column styles. ‣ Centralizing colors (and images) makes for easier, and better customization. Maintenance profit. ‣ Leverage Sass mixins & functions to reproduce graphics to eliminate shipping with resolution-limited bitmaps. ‣ CSS3 animations & transformations bring themes alive! 14
  • 15. Mobile - BOOM! Now be RESPONSIVE ‣ This is your next frontier when done with Sass basics. ‣ Good excuse to buy that tablet or any other device. ‣ Motivation to use SVG along with PNG. 15
  • 16. CSS3 - BOOM! Build on top of CSS3 ‣ This is the new frontier in standards compliance. ‣ Another good excuse to buy that new tablet/device. ‣ Another excuse to use SVG along with PNG. 16