SlideShare a Scribd company logo
Diazo:
Bridging Designers and Programmers
marr
Bridging
Designers
Programmers
and
進化中的程式猿
Which Group Do You Belong To?
Web Development Pipeline
Web Development Pipeline
Collaboration
vs CrossOver
Front-end
HTML
JavaScript
Database
APIs
Back-end
Business
Logic
Task Boundary
O HTML
O CSS
O Multimedia
X Shell Commands
? JavaScript
? Version Control
Task Boundary
Anything
Else !
O HTML
O CSS
O Multimedia
X Shell Commands
? JavaScript
? Version Control
CMS Wars
Plone Looks Not Sexy
Joo-Dru Skins, Plone Goodies
豬皮 龍骨
Joo-Dru Skins, Plone Goodies
Introducing Diazo
di-az-o (also di-az-o-type)
noun
a copying or coloring process using a
diazo compound decomposed by
ultraviolet light
How Diazo Works
HTML
Mockup
Unthemed
Content
HTML
Mockup
Unthemed
Content
How Diazo Works
XML
Rules
How Diazo Works
How Diazo Works
How rules.xml Looks Like
<?xml version="1.0" encoding="UTF-8"?>
<rules
xmlns="http://namespaces.plone.org/diazo"
xmlns:css="http://namespaces.plone.org/diazo/css"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<rules css:if-content="#visual-portal-wrapper">
<theme href="theme.html" />
…
</rules>
</rules>
Theme Editor
Rule Directives
<theme />
<replace />
<drop />
<before />
<after />
<copy />
<merge />
<strip />
Compile and Deploy
• With Theme HTML and Rule in hand, you can
compile these using the Diazo compiler into a
single XSLT file.
• You can then deploy this XSLT file with your
application.
• An XSLT processor (such as mod_transform in
Apache) will then transform the dynamic content
from your website into the themed content your
end users see.
• The transformation takes place on-the-fly for each
request.
先別管技術了…
你聽過Ang Lee嗎?
Paint It Plone!
Replacing Page Title
and Main Content
<replace css:theme="html head title"
css:content="html head title"/>
<replace css:theme-children=".blog .content"
css:content-children="#content"/>
Including Content’s Scripts
and Meta Data
<before css:theme-children="html head"
css:content="html head script" />
<before css:theme-children="html head“
css:content="html head meta" />
Content’s Navigation Bar
<ul id="portal-globalnav">
<li id="portaltab-index_html" class="selected">
<a href="http://..." title="">Home</a>
</li>
<li id="portaltab-news" class="plain">
<a href="http://..." title="Site News">News</a>
</li>
...
</ul>
Theme’s Navigation Bar
<nav class ="top-nav">
<div class="shell">
<a href="#" class="nav-btn">HOMEPAGE<span></span></a>
<span class="top-nav-shadow"></span>
<ul> <li class="active first">
<span><a href="#">home</a></span></li>
<li><span><a href="#">services</a></span></li>
...
<li class="last">
<span><a href="#">contacts</a></span></li>
</ul>
</div>
</nav>
Replacing Navigation Bar
<replace css:theme-children="nav.top-nav ul">
<xsl:for-each css:select="#portal-globalnav li">
<li><span><xsl:copy-of css:select="a"/>
</span></li>
</xsl:for-each>
</replace>
Adding Login Button
<before css:theme-children='body'
css:content='#portal-personaltools-
wrapper' />
<drop css:content=".searchSection" />
Some Other Scenario
• Management Interface Usually
Needs a Vanilla or Separate Face
• Maintain and Serve Themes in
Version Control System
• Keep Organization Themes Looking
Consistent
• 豬皮龍骨 Ya!
Conclusion
• Make Use of the Unique CSS Bits
• Use Example Codes / Recipes First
for Learning, then Use Editor For
Obvious Tasks
• Resource: QAs on StackOverflow
<… css:if-content=“.template-controlpanel” />
Credits
David Bain
https://docs.google.com/document/d/1
1OUaVbk2cJ7dH127wXat-
S4yqHGJb3CUNKT2HAidVso

More Related Content

PDF
Plone 5 theming unleashed
PPTX
5 things STILL! TOO! HARD! in Plone 5
PDF
Plone 5 theming
PDF
Killing the Angle Bracket
ODP
Plone for python programmers
ODP
TTW FTW: Plone as the new wordpress
PDF
Plone Futures
PDF
Plone server
Plone 5 theming unleashed
5 things STILL! TOO! HARD! in Plone 5
Plone 5 theming
Killing the Angle Bracket
Plone for python programmers
TTW FTW: Plone as the new wordpress
Plone Futures
Plone server

What's hot (18)

PDF
Using Core Themes in Drupal 8
PDF
Best Practice Site Architecture in Drupal 8
PDF
Plone.restapi - a bridge to the modern web
PDF
Add-On Development: EE Expects that Every Developer will do his Duty
PDF
The Future of the Web: HTML5
PDF
Introduction to html 5
PDF
Bootstrap Framework and Drupal
PPTX
Webdev CCI Tel U - Introduction to HTML 5.0
PDF
Theming in WordPress - Where do I Start?
PDF
Git Makes Me Angry Inside
KEY
Learn Drupal's Most Powerful Site-Building Modules: Display Suite, Context, V...
PPT
Drupal - Introduction to Drupal and Web Content Management
PDF
OpenERP and Perl
PDF
Modern Front-End Development
PDF
Grok Drupal (7) Theming
PDF
Managing a Project the Drupal Way - Drupal Open Days Ireland
PPTX
Joomla! Pizza Bugs and Fun 2014 pre-event Seminar
PPT
Creating Responsive Drupal Sites with Zen Grids and the Zen 5 Theme
Using Core Themes in Drupal 8
Best Practice Site Architecture in Drupal 8
Plone.restapi - a bridge to the modern web
Add-On Development: EE Expects that Every Developer will do his Duty
The Future of the Web: HTML5
Introduction to html 5
Bootstrap Framework and Drupal
Webdev CCI Tel U - Introduction to HTML 5.0
Theming in WordPress - Where do I Start?
Git Makes Me Angry Inside
Learn Drupal's Most Powerful Site-Building Modules: Display Suite, Context, V...
Drupal - Introduction to Drupal and Web Content Management
OpenERP and Perl
Modern Front-End Development
Grok Drupal (7) Theming
Managing a Project the Drupal Way - Drupal Open Days Ireland
Joomla! Pizza Bugs and Fun 2014 pre-event Seminar
Creating Responsive Drupal Sites with Zen Grids and the Zen 5 Theme
Ad

Viewers also liked (7)

PPTX
Happen Coworking Granada
PPTX
Workteam with oDesk
PDF
Sahana Taiwan Development
PDF
eGos Project: Innovation for eGovernment- www.egos-cip.eu
PPT
Introduction to Python Programming
PDF
Python for Application Integration and Development
PPT
CMS Showdown For NPO
Happen Coworking Granada
Workteam with oDesk
Sahana Taiwan Development
eGos Project: Innovation for eGovernment- www.egos-cip.eu
Introduction to Python Programming
Python for Application Integration and Development
CMS Showdown For NPO
Ad

Similar to Diazo: Bridging Designers and Programmers (7)

PPTX
World Plone Day 2012 Taipei
PDF
Death of a Themer
ODP
Plone - A Comprehensive Content Management Solution
PDF
CCSP 2012F 早點下班的工具
PDF
How diazo works
PDF
David Convent - Theme It Yourself
PDF
Plog2014 - Saucelabs - a perspective on tiles to empower your plone editors
World Plone Day 2012 Taipei
Death of a Themer
Plone - A Comprehensive Content Management Solution
CCSP 2012F 早點下班的工具
How diazo works
David Convent - Theme It Yourself
Plog2014 - Saucelabs - a perspective on tiles to empower your plone editors

More from TsungWei Hu (14)

PDF
Odoo Development
PDF
開源教 教我 Odoo 管理 ERP 和 CRM
PDF
Plone Zwiki
PDF
Ten Years After: An Integrator's Tale
PPTX
from passion import profession
PPTX
Computer Programming For Everyone
PPTX
ElasticSearch Introduction
PPTX
Open Source Technologies for Contents and Maps
PPTX
The Zen of Language Choice
PPTX
Build Python CMS The Plone Way
PDF
Plone -- Evolving Python CMS
PDF
Proud Plone on Cloud
PDF
Python - A Comprehensive Programming Language
PPT
Developing with pyGTK in EeePC
Odoo Development
開源教 教我 Odoo 管理 ERP 和 CRM
Plone Zwiki
Ten Years After: An Integrator's Tale
from passion import profession
Computer Programming For Everyone
ElasticSearch Introduction
Open Source Technologies for Contents and Maps
The Zen of Language Choice
Build Python CMS The Plone Way
Plone -- Evolving Python CMS
Proud Plone on Cloud
Python - A Comprehensive Programming Language
Developing with pyGTK in EeePC

Recently uploaded (20)

PDF
Profit Center Accounting in SAP S/4HANA, S4F28 Col11
PDF
A comparative study of natural language inference in Swahili using monolingua...
PPTX
Digital-Transformation-Roadmap-for-Companies.pptx
PDF
Mushroom cultivation and it's methods.pdf
PPT
Teaching material agriculture food technology
PPTX
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
PDF
Machine learning based COVID-19 study performance prediction
PDF
Empathic Computing: Creating Shared Understanding
PDF
Unlocking AI with Model Context Protocol (MCP)
PDF
Per capita expenditure prediction using model stacking based on satellite ima...
PDF
Diabetes mellitus diagnosis method based random forest with bat algorithm
PDF
Video forgery: An extensive analysis of inter-and intra-frame manipulation al...
PPTX
Machine Learning_overview_presentation.pptx
PDF
Mobile App Security Testing_ A Comprehensive Guide.pdf
PDF
Network Security Unit 5.pdf for BCA BBA.
PDF
Encapsulation_ Review paper, used for researhc scholars
PDF
August Patch Tuesday
PDF
Building Integrated photovoltaic BIPV_UPV.pdf
PDF
MIND Revenue Release Quarter 2 2025 Press Release
PPTX
TLE Review Electricity (Electricity).pptx
Profit Center Accounting in SAP S/4HANA, S4F28 Col11
A comparative study of natural language inference in Swahili using monolingua...
Digital-Transformation-Roadmap-for-Companies.pptx
Mushroom cultivation and it's methods.pdf
Teaching material agriculture food technology
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
Machine learning based COVID-19 study performance prediction
Empathic Computing: Creating Shared Understanding
Unlocking AI with Model Context Protocol (MCP)
Per capita expenditure prediction using model stacking based on satellite ima...
Diabetes mellitus diagnosis method based random forest with bat algorithm
Video forgery: An extensive analysis of inter-and intra-frame manipulation al...
Machine Learning_overview_presentation.pptx
Mobile App Security Testing_ A Comprehensive Guide.pdf
Network Security Unit 5.pdf for BCA BBA.
Encapsulation_ Review paper, used for researhc scholars
August Patch Tuesday
Building Integrated photovoltaic BIPV_UPV.pdf
MIND Revenue Release Quarter 2 2025 Press Release
TLE Review Electricity (Electricity).pptx

Diazo: Bridging Designers and Programmers