Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Diazo - XSLT basiertes Website Theming
Search
Maik Derstappen
August 25, 2012
Programming
75
2
Share
Diazo - XSLT basiertes Website Theming
Flexibel, schnell und einfach für Plone und den Rest der Welt
Maik Derstappen
August 25, 2012
More Decks by Maik Derstappen
See All by Maik Derstappen
Diazo - XSLT basiertes Website Theming
mrtango
0
110
Other Decks in Programming
See All in Programming
VueエンジニアがReactを触って感じた_設計の違い
koukimiura
0
160
おれのAgentic Coding 2026/03
tsukasagr
1
140
Smarter Angular mit Transformers.js & Prompt API
christianliebel
PRO
1
120
Radical Imagining - LIFT 2025-2027 Policy Agenda
lift1998
0
250
存在論的プログラミング: 時間と存在を記述する
koriym
5
840
Laravel Nightwatchの裏側 - Laravel公式Observabilityツールを支える設計と実装
avosalmon
1
320
Symfonyの特性(設計思想)を手軽に活かす特性(trait)
ickx
0
130
Strategy for Finding a Problem for OSS: With Real Examples
kibitan
0
140
PHP で mp3 プレイヤーを実装しよう
m3m0r7
PRO
0
190
仕様漏れ実装漏れをなくすトレーサビリティAI基盤のご紹介
orgachem
PRO
9
5.1k
ネイティブアプリとWebフロントエンドのAPI通信ラッパーにおける共通化の勘所
suguruooki
0
250
Go_College_最終発表資料__外部公開用_.pdf
xe_pc23
0
140
Featured
See All Featured
The innovator’s Mindset - Leading Through an Era of Exponential Change - McGill University 2025
jdejongh
PRO
1
150
Intergalactic Javascript Robots from Outer Space
tanoku
273
27k
Git: the NoSQL Database
bkeepers
PRO
432
67k
Neural Spatial Audio Processing for Sound Field Analysis and Control
skoyamalab
0
250
Navigating the Design Leadership Dip - Product Design Week Design Leaders+ Conference 2024
apolaine
0
270
Code Reviewing Like a Champion
maltzj
528
40k
Taking LLMs out of the black box: A practical guide to human-in-the-loop distillation
inesmontani
PRO
3
2.1k
Reflections from 52 weeks, 52 projects
jeffersonlam
356
21k
Rebuilding a faster, lazier Slack
samanthasiow
85
9.4k
Introduction to Domain-Driven Design and Collaborative software design
baasie
1
720
Abbi's Birthday
coloredviolet
2
6.5k
Designing Experiences People Love
moore
143
24k
Transcript
Diazo XSLT basiertes Website Theming Maik Derstappen – Inqbus GmbH
& Co. KG –
[email protected]
Flexibel, schnell und einfach für Plone und den Rest der
Welt
Was wir haben
None
Wie es aussehen soll
None
None
None
None
Diazo + plone.app.theming
None
<replace css:content='#portal-globalnav li' css:theme-children='#global-navigation' /> Die Hauptnavigationspunkte übernehmen
<replace css:content="#content" css:theme="#content" /> Den Seiteninhalt übernehmen
<after css:content='.portlet.portletNews' css:theme-children='#portal-column-two' /> Das Nachrichten-Portlet übernehmen
<after css:content-children='#portal-column-two' css:theme-children='#portal-column-two' /> Alle Portlets der rechten Spalte übernehmen
<after css:content='#portal-column-two .portlet:not(.portletNavigationTree)' css:theme-children='#portal-column-two' /> Alle Portlets bis auf Navigation
übernehmen
#portal-column-two .portlet:not(.portletNavigationTree) Alle Portlets bis auf Navigation übernehmen
Diazo rules.xml Grundgerüst
<?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>
Diazo rules.xml Definition
<rules css:if-content="#visual-portal-wrapper"> <after content="/html/head/script" theme-children="/html/head" /> <replace css:content='#portal-globalnav li' css:theme-children='#portal-globalnav'
/> <replace css:content-children="#content" css:theme-children="#content" /> <after css:content='.portlet.portletNews' css:theme-children='#portal-column-two' /> </rules>
statische Template-Datei definieren
<rules css:if-content="#visual-portal-wrapper"> <theme href="index.html" css:if-content="body.section-front-page" /> <theme href="index.html" css:if-content="body.portaltype-plone-site" />
<theme href="article.html" /> <notheme css:if-content="body.rawpage" /> </rules>
Diazo – Regeln (Rules)
XPath oder CSS3? Diazo unterstützt sowohl XPath- als auch CSS3-Selektoren
in Regeln.
XPath <after content="//div[@id='portal-column-one'] //*[contains(@class, 'portlet')]" theme=“//div[@id='portal-column-one']“ />
CSS3 <after css:content="#portal-column-one .portlet" css:theme=“#portal-column-one“ />
XPath- und CSS3-Selektoren führen zu identischen Ergebnissen, da die CSS3-Selektoren
in XPath umgewandelt werden
theme-children / content-children Wird die children-Variante verwendet, so betrifft die
Anweisung, die im gefundenen Element enthaltenen Kind-Elemente, nicht das Element selbst
- theme - notheme - replace - before / after
- drop - strip - merge - copy
<theme />
theme gibt die Template-Datei für das Theme an <theme href="index.html"
css:if-content="body.section-front-page" /> <theme href="article.html" />
<notheme />
notheme deaktiviert das Theming, dies kann zusammen mit Bedingungen eingesetzt
werden <notheme css:if-content="body.rawpage" />
<replace />
replace ersetzt ein Element im Theme mit einem Element aus
dem content <replace css:content="#edit-bar" css:theme="#edit-bar" /> <replace css:content-children="#content" css:theme-children="#content" />
<after /> & <before />
after & before fügen ein Element aus dem Content vor
/ nach einem Element im Theme ein <before css:content='.portlet.portletNavigationTree' css:theme-children='#portal-column-two' /> <after content-children="#portal-column-two" theme-children="#portal-column-two" />
<copy />
copy kopiert Attribute aus dem Content ins Theme <copy attributes="id
dir" css:content="body" css:theme="body" />
<merge />
merge vereint Attribute aus dem Content mit vorhandenen Attributen im
Theme <merge attributes="class" css:content="body" css:theme="body" />
<drop />
drop entfernt Elemente / Attribute aus dem Theme oder Content
<drop css:theme=".portletNavigationTree" attributes="class id" /> <drop css:content="#portal-searchbox .searchSection" />
<strip />
strip entfernt ein Element aus dem Theme oder Content, erhält
aber den Inhalt des Elementes <strip css:content=".portletWrapper" />
Feste Ausführreihenfolge von Diazo Regeln!
1. before - Regeln für (theme) 2. drop - Regeln
3. replace - Regeln (theme) 4. strip - Regeln 5. Regeln die Attribute verändern 6. before, replace, after - Regeln (theme-children) 7. after – Regeln (theme) Ausführreihenfolge von Diazo-Regeln
Dank plone.app.theming können Diazo-Themes per ZIP-Datei und ohne Neustart in
Plone installiert werden. Diazo-Theme als ZIP-Datei
Einfaches Verzeichnis mit statischen Dateien + rules.xml + manifest.cfg [wpd]
├── article.html ├── images │ ├── icon-home.gif │ ├── icon-mail.gif │ ├── input-bg.gif │ ├── link1-bg.gif │ ├── logo.jpg │ ├── main-bg.jpg ├── index.html ├── manifest.cfg ├── rules.xml └── style.css
[theme] title="Plone Theme: PloneKonf 2012" description = "Plone Theme for
the first german Plone conference." manifest.cfg – mit Metadaten
None
Es ist möglich Inhalte weiterer Quellen einzubinden
<after css:theme-content="#content" css:content="#content" href="@@custom_view" /> Einbinden weiterer Quellen
Dies funktioniert auch für externe Websites und Web-Anwendungen!
<replace css:content-children="#content-core .panes" css:theme-children=".col-1 .section" href="http://konferenz.plone.de/programm" /> Einbinden externer Systeme
Dies eröffnet umfangreiche Möglichkeiten, verschiedene Systeme nahtlos und barrierefrei in
Plone zu integrieren. Einbinden externer Systeme
None
<replace css:content-children="#spTeaserColumn" css:theme-children="#press_table .left" href="http://www.spiegel.de" if-path="presse/" /> <replace css:content=".teaserlist" css:theme-children="#press_table
.right" href="http://www.zeit.de/" if-path="presse/" /> Einbinden von nicht Plone-Systemen
None
Snippets
<replace content="//dl[contains(@class,'portlet- collection-links')]//a" method="raw"> <xsl:attribute name="target">_blank</xsl:attribute> </replace> Snippets Link in
Kollektions-Portlets mit target=“_blank“
Vielen Dank Fragen ? plone.app.theming: PyPi Diazo: http://diazo.org Development &
Consulting: http://inqbus.de Hosting: http://plone-hosting.de