SlideShare a Scribd company logo
1 of 27
Download to read offline
MY WIFE’S
WEBSITE
Jigal van Hemert
jigal.van.hemert@typo3.org
@jigalvh
A look at building a website
15/07/2017 My wife’s website 2
GOAL
15/07/2017 My wife’s website 3
SITEPACKAGE
CONCEPT
All configuration in an extension
15/07/2017 My wife’s website 4
SITEPACKAGE
 TypoScript, TSconfig
 BE layouts, Fluid templates
 ViewHelpers
 DataProcessors
15/07/2017 My wife’s website 5
EXISTING
TEMPLATE
Let’s be modern and use bootstrap
15/07/2017 My wife’s website 6
...
15/07/2017 My wife’s website 7
COMPLEX
CONDITIONS
<f.spaceless> to the rescue
15/07/2017 My wife’s website 8
COMPLEX CONDITIONS
<f:spaceless>
<f:if condition="{0: hasMenu, 1: count} == {0: 1, 1: 2}"><f:then>4</f:then></f:if>
<f:if condition="{0: hasMenu, 1: count} == {0: 1, 1: 3}"><f:then>3</f:then></f:if>
<f:if condition="{0: hasMenu, 1: count} == {0: 1, 1: 4}"><f:then>2</f:then></f:if>
<f:if condition="{0: hasMenu, 1: count} == {0: 0, 1: 2}"><f:then>6</f:then></f:if>
<f:if condition="{0: hasMenu, 1: count} == {0: 0, 1: 3}"><f:then>4</f:then></f:if>
<f:if condition="{0: hasMenu, 1: count} == {0: 0, 1: 4}"><f:then>3</f:then></f:if>
</f:spaceless>
15/07/2017 My wife’s website 9
COMPLEX CONDITIONS
<div class="col-md-{f:render(
partial:'Helpers/bootstrapCol',
arguments:'{hasMenu: hasMenu, count: cols}'
)}">
15/07/2017 My wife’s website 10
AUTOCOMPLETE &
CLEAN-UP
Namespaces for IDE
15/07/2017 My wife’s website 11
AUTOCOMPLETE & CLEAN-UP
<html
xmlns:f="https://typo3.org/ns/TYPO3/CMS/Fluid/ViewHelpers"
data-namespace-typo3-fluid="true">
…
</html>
15/07/2017 My wife’s website 12
AUTOCOMPLETE & CLEAN-UP
 xmlns: for auto-complete in IDE
 data-attribute to remove tag
15/07/2017 My wife’s website 13
DROP-IN PARTIAL
Cleaner template structure
15/07/2017 My wife’s website 14
FLUIDCONTENT TEMPLATE STRUCTURE
 No HeaderContentFooter.hml
 Instead:
–DropIn/Before/All.html
–DropIn/After/All.html
15/07/2017 My wife’s website 15
TABLE CONTENT
ELEMENT???
Old things looking new
15/07/2017 My wife’s website 16
TABLE CONTENT ELEMENT
 Simple interface
 No markup in cells
 Responsive output
15/07/2017 My wife’s website 17
DEFAULT CONTENT
No empty pages
15/07/2017 My wife’s website 18
lib.content0 < styles.content.get
lib.content0.stdWrap.ifEmpty =
<section><div class="container"><div
class="row"><div class="col-md-12 text-
center"><h2>Under Construction</h2>
<p>Content will be added shortly</p>
</div></div></div></section>
DEFAULT CONTENT
15/07/2017 My wife’s website 19
MEGA MENU WITH
BREAKS
Also as hamburger menu
15/07/2017 My wife’s website 20
MEGA MENU
 Normal HMENU
 SPC as column separator
 Use field media to trigger mega-menu
 Pid field to check for third level
15/07/2017 My wife’s website 21
GALLERY CE
Gallery from folder
15/07/2017 My wife’s website 22
GALLERY CONTENT ELEMENT
 FlexForm DataProcessor
 SPC as column separator
 Use field media to trigger mega-menu
 Pid field to check for third level
15/07/2017 My wife’s website 23
GALLERY CONTENT ELEMENT
DataProcessing {
10 = jigalnoytcbDataProcessingFlexFormProcessor
10 {
as = flexformData
}
20 = jigalnoytcbDataProcessingFilesProcessor
20 {
foldersProcessedDataKey = flexformData|folder
sorting = name
copyProcessedDataToData = flexformData|imagecols
as = files
}
30 = TYPO3CMSFrontendDataProcessingGalleryProcessor
30 {
filesProcessedDataKey = files
maxGalleryWidth = 1500
as = gallery
}
}
15/07/2017 My wife’s website 24
GALLERY CONTENT ELEMENT
settings.media.popup.linkParams.ATagParams.dataWrap =
class="{$styles.content.textmedia.linkWrap.lightboxCss
Class}" data-
toggle="{$styles.content.textmedia.linkWrap.lightboxTo
ggleAttribute}" data-gallery="gallery" data-
title="{column.media.title}" data-
footer="{column.media.description}"
15/07/2017 My wife’s website 25
DISCUSSION
15/07/2017 My wife’s website 26
THANK YOU!
15/07/2017 My wife’s website 27

More Related Content

More from Jigal van Hemert (6)

Little Gems in TYPO3 v12
Little Gems in TYPO3 v12Little Gems in TYPO3 v12
Little Gems in TYPO3 v12
 
Fun with fluid (TYPO3camp RheinRuhr 2019)
Fun with fluid (TYPO3camp RheinRuhr 2019)Fun with fluid (TYPO3camp RheinRuhr 2019)
Fun with fluid (TYPO3camp RheinRuhr 2019)
 
Build your own Upgrade Wizard
Build your own Upgrade WizardBuild your own Upgrade Wizard
Build your own Upgrade Wizard
 
Little gems in TYPO3 v9
Little gems in TYPO3 v9Little gems in TYPO3 v9
Little gems in TYPO3 v9
 
Fun with fluid_t3dd18
Fun with fluid_t3dd18Fun with fluid_t3dd18
Fun with fluid_t3dd18
 
Ddev workshop t3dd18
Ddev workshop t3dd18Ddev workshop t3dd18
Ddev workshop t3dd18
 

Recently uploaded

TECUNIQUE: Success Stories: IT Service provider
TECUNIQUE: Success Stories: IT Service providerTECUNIQUE: Success Stories: IT Service provider
TECUNIQUE: Success Stories: IT Service provider
mohitmore19
 
introduction-to-automotive Andoid os-csimmonds-ndctechtown-2021.pdf
introduction-to-automotive Andoid os-csimmonds-ndctechtown-2021.pdfintroduction-to-automotive Andoid os-csimmonds-ndctechtown-2021.pdf
introduction-to-automotive Andoid os-csimmonds-ndctechtown-2021.pdf
VishalKumarJha10
 
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
Health
 

Recently uploaded (20)

The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
 
5 Signs You Need a Fashion PLM Software.pdf
5 Signs You Need a Fashion PLM Software.pdf5 Signs You Need a Fashion PLM Software.pdf
5 Signs You Need a Fashion PLM Software.pdf
 
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
 
Microsoft AI Transformation Partner Playbook.pdf
Microsoft AI Transformation Partner Playbook.pdfMicrosoft AI Transformation Partner Playbook.pdf
Microsoft AI Transformation Partner Playbook.pdf
 
TECUNIQUE: Success Stories: IT Service provider
TECUNIQUE: Success Stories: IT Service providerTECUNIQUE: Success Stories: IT Service provider
TECUNIQUE: Success Stories: IT Service provider
 
HR Software Buyers Guide in 2024 - HRSoftware.com
HR Software Buyers Guide in 2024 - HRSoftware.comHR Software Buyers Guide in 2024 - HRSoftware.com
HR Software Buyers Guide in 2024 - HRSoftware.com
 
The Ultimate Test Automation Guide_ Best Practices and Tips.pdf
The Ultimate Test Automation Guide_ Best Practices and Tips.pdfThe Ultimate Test Automation Guide_ Best Practices and Tips.pdf
The Ultimate Test Automation Guide_ Best Practices and Tips.pdf
 
Unlocking the Future of AI Agents with Large Language Models
Unlocking the Future of AI Agents with Large Language ModelsUnlocking the Future of AI Agents with Large Language Models
Unlocking the Future of AI Agents with Large Language Models
 
Introducing Microsoft’s new Enterprise Work Management (EWM) Solution
Introducing Microsoft’s new Enterprise Work Management (EWM) SolutionIntroducing Microsoft’s new Enterprise Work Management (EWM) Solution
Introducing Microsoft’s new Enterprise Work Management (EWM) Solution
 
Unveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
Unveiling the Tech Salsa of LAMs with Janus in Real-Time ApplicationsUnveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
Unveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
 
Optimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTVOptimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTV
 
The Guide to Integrating Generative AI into Unified Continuous Testing Platfo...
The Guide to Integrating Generative AI into Unified Continuous Testing Platfo...The Guide to Integrating Generative AI into Unified Continuous Testing Platfo...
The Guide to Integrating Generative AI into Unified Continuous Testing Platfo...
 
How To Use Server-Side Rendering with Nuxt.js
How To Use Server-Side Rendering with Nuxt.jsHow To Use Server-Side Rendering with Nuxt.js
How To Use Server-Side Rendering with Nuxt.js
 
Exploring the Best Video Editing App.pdf
Exploring the Best Video Editing App.pdfExploring the Best Video Editing App.pdf
Exploring the Best Video Editing App.pdf
 
introduction-to-automotive Andoid os-csimmonds-ndctechtown-2021.pdf
introduction-to-automotive Andoid os-csimmonds-ndctechtown-2021.pdfintroduction-to-automotive Andoid os-csimmonds-ndctechtown-2021.pdf
introduction-to-automotive Andoid os-csimmonds-ndctechtown-2021.pdf
 
Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
 
How To Troubleshoot Collaboration Apps for the Modern Connected Worker
How To Troubleshoot Collaboration Apps for the Modern Connected WorkerHow To Troubleshoot Collaboration Apps for the Modern Connected Worker
How To Troubleshoot Collaboration Apps for the Modern Connected Worker
 
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdfLearn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
 
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
 
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
 

My Wife's Website