SlideShare a Scribd company logo
1 of 9
A modular approach to Forms
13 July 2015 • SilverStripe London • Dan Hensby
Why modular forms?
● Keep related logic in one place
● Have a single point of truth for forms
● Form re-use is easy
● Add logic to all forms in one go
● Remove logic from your controller
● Provide a common interface for defining forms in you project
Here we are:
● Defining an abstract class to create
our common interface
● Making most constructor arguments
optional
● Using internal class methods to define
Fields, Actions & Validator
Now we have a common API for creating
forms
A base form
Defining an interface and API for your forms
Here we are:
● Defining a simple contact form
● Adding fields
● Setting the button label
● Making the fields required
● Defining the submission handler `doSubmit`
● Using `Config` to assign defaults for the outgoing
email
Creating a contact form
We’ve defined a simple Email
Template for contact form
submissions
Create a simple email template
We’ve all done this before
Here we have:
● Added `Form` and `success` as “allowed
action”
● Defined a `Form` method to create the
`ContactForm`
● Defined a `success` action on the
controller (and template)
We have removed the logic around the
`ContactForm` from the controller
Set up the controller
● Since 3.0 styling form fields has become simple
● We can add custom template files to override the
markup
● We can work around default behaviour of duplicated
classnames
● In 3.2 we can add default class names to forms and
fields
Styling the front end form
● Using BEM to write clear CSS
● Block Element Modifier
● .block .block__element .block__element--modifier
● Best used with a CSS pre-processor
● Solves many common issues with
CSS on (large) projects
Resources:
● https://en.bem.info/
● http://cssguidelin.es/
Creating simple CSS
Thank you!
Code here: http://bit.ly/ss3forms
Twitter/GitHub/etc: @dhensby

More Related Content

Viewers also liked

Tradersecrets14
Tradersecrets14Tradersecrets14
Tradersecrets14ecarfor
 
Build booming mindset
Build booming mindsetBuild booming mindset
Build booming mindsethemalkmanek
 
Open It, Read It, Buy It Email Marketing with the AppExchange
Open It, Read It, Buy It Email Marketing with the AppExchangeOpen It, Read It, Buy It Email Marketing with the AppExchange
Open It, Read It, Buy It Email Marketing with the AppExchangedreamforce2006
 
Manual daniel ponce
Manual daniel ponceManual daniel ponce
Manual daniel ponceMoreePonce
 
plan evaluacion bajo el enfoque conductista, contructivista y contexto ecolo...
plan  evaluacion bajo el enfoque conductista, contructivista y contexto ecolo...plan  evaluacion bajo el enfoque conductista, contructivista y contexto ecolo...
plan evaluacion bajo el enfoque conductista, contructivista y contexto ecolo...Michel Cassiani
 
Observatorio de Clima Emprendedor 2012
Observatorio de Clima Emprendedor 2012Observatorio de Clima Emprendedor 2012
Observatorio de Clima Emprendedor 2012iniciadoremprendedores
 
Pasos para lograr una buena salud financiera empresarial
Pasos para lograr una buena salud financiera empresarialPasos para lograr una buena salud financiera empresarial
Pasos para lograr una buena salud financiera empresarialLaura Lima
 
hydraulic power solution faridabad , cnc solution
hydraulic power solution faridabad , cnc solutionhydraulic power solution faridabad , cnc solution
hydraulic power solution faridabad , cnc solutionVISHALPACHORIJI
 
Estilo de dirección orientativo. Dar visión estratégica al equipo.
Estilo de dirección orientativo. Dar visión estratégica al equipo. Estilo de dirección orientativo. Dar visión estratégica al equipo.
Estilo de dirección orientativo. Dar visión estratégica al equipo. mbformacion
 
O chifre pequeno de daniel 7 e a primeira besta de apocalipse 13
O chifre pequeno de daniel 7 e a primeira besta de apocalipse 13O chifre pequeno de daniel 7 e a primeira besta de apocalipse 13
O chifre pequeno de daniel 7 e a primeira besta de apocalipse 13Diego Fortunatto
 

Viewers also liked (19)

E-mail
E-mailE-mail
E-mail
 
Tradersecrets14
Tradersecrets14Tradersecrets14
Tradersecrets14
 
Build booming mindset
Build booming mindsetBuild booming mindset
Build booming mindset
 
Mapa metro
Mapa metroMapa metro
Mapa metro
 
Open It, Read It, Buy It Email Marketing with the AppExchange
Open It, Read It, Buy It Email Marketing with the AppExchangeOpen It, Read It, Buy It Email Marketing with the AppExchange
Open It, Read It, Buy It Email Marketing with the AppExchange
 
14 15
14 1514 15
14 15
 
Manual daniel ponce
Manual daniel ponceManual daniel ponce
Manual daniel ponce
 
2005_matzon
2005_matzon2005_matzon
2005_matzon
 
Grupo mota
Grupo motaGrupo mota
Grupo mota
 
plan evaluacion bajo el enfoque conductista, contructivista y contexto ecolo...
plan  evaluacion bajo el enfoque conductista, contructivista y contexto ecolo...plan  evaluacion bajo el enfoque conductista, contructivista y contexto ecolo...
plan evaluacion bajo el enfoque conductista, contructivista y contexto ecolo...
 
Observatorio de Clima Emprendedor 2012
Observatorio de Clima Emprendedor 2012Observatorio de Clima Emprendedor 2012
Observatorio de Clima Emprendedor 2012
 
TRACCIÓN CADENA SUMINISTRO: COMPRA PRIVADA VERDE, INTRODUCCIÓN DE CRITERIOS A...
TRACCIÓN CADENA SUMINISTRO: COMPRA PRIVADA VERDE, INTRODUCCIÓN DE CRITERIOS A...TRACCIÓN CADENA SUMINISTRO: COMPRA PRIVADA VERDE, INTRODUCCIÓN DE CRITERIOS A...
TRACCIÓN CADENA SUMINISTRO: COMPRA PRIVADA VERDE, INTRODUCCIÓN DE CRITERIOS A...
 
Software One Corporativa
Software One Corporativa Software One Corporativa
Software One Corporativa
 
Pasos para lograr una buena salud financiera empresarial
Pasos para lograr una buena salud financiera empresarialPasos para lograr una buena salud financiera empresarial
Pasos para lograr una buena salud financiera empresarial
 
Beacons
BeaconsBeacons
Beacons
 
hydraulic power solution faridabad , cnc solution
hydraulic power solution faridabad , cnc solutionhydraulic power solution faridabad , cnc solution
hydraulic power solution faridabad , cnc solution
 
Estilo de dirección orientativo. Dar visión estratégica al equipo.
Estilo de dirección orientativo. Dar visión estratégica al equipo. Estilo de dirección orientativo. Dar visión estratégica al equipo.
Estilo de dirección orientativo. Dar visión estratégica al equipo.
 
O chifre pequeno de daniel 7 e a primeira besta de apocalipse 13
O chifre pequeno de daniel 7 e a primeira besta de apocalipse 13O chifre pequeno de daniel 7 e a primeira besta de apocalipse 13
O chifre pequeno de daniel 7 e a primeira besta de apocalipse 13
 
Studying Migrations Routes: New data and Tools
Studying Migrations Routes: New data and ToolsStudying Migrations Routes: New data and Tools
Studying Migrations Routes: New data and Tools
 

Similar to Modular forms in SilverStripe 3

Data analysis with Postgres and Power BI
Data analysis with Postgres and Power BIData analysis with Postgres and Power BI
Data analysis with Postgres and Power BISangeetha Subramani
 
PDF in Lotus Notes applications
PDF in Lotus Notes applicationsPDF in Lotus Notes applications
PDF in Lotus Notes applicationsSWING Software
 
Managing requirements with user stories
Managing requirements with user storiesManaging requirements with user stories
Managing requirements with user storiesVishal Prasad
 
Industrail training report on website design and development
Industrail training report on website design and developmentIndustrail training report on website design and development
Industrail training report on website design and developmentMUSICbegins
 
aCtive Collabs in Quick Review
aCtive Collabs in Quick ReviewaCtive Collabs in Quick Review
aCtive Collabs in Quick ReviewRisna Cahyati
 
Workday Integration Online Training.pdf
Workday Integration Online Training.pdfWorkday Integration Online Training.pdf
Workday Integration Online Training.pdfSpiritsoftsTraining
 
Intuit Quickbase Empower 2015 - Finish Strong: SUCCESSFULLLY ROLLING OUT YOUR...
Intuit Quickbase Empower 2015 - Finish Strong: SUCCESSFULLLY ROLLING OUT YOUR...Intuit Quickbase Empower 2015 - Finish Strong: SUCCESSFULLLY ROLLING OUT YOUR...
Intuit Quickbase Empower 2015 - Finish Strong: SUCCESSFULLLY ROLLING OUT YOUR...John Head
 
Web Development and Design Final ProjectBefore you begin the p.docx
Web Development and Design Final ProjectBefore you begin the p.docxWeb Development and Design Final ProjectBefore you begin the p.docx
Web Development and Design Final ProjectBefore you begin the p.docxmelbruce90096
 
MuleSoftMeetup-B2BIntegrations_using_MuleSoft
MuleSoftMeetup-B2BIntegrations_using_MuleSoftMuleSoftMeetup-B2BIntegrations_using_MuleSoft
MuleSoftMeetup-B2BIntegrations_using_MuleSoftMulesoftMunichMeetup
 
Finish Strong -- Successfully Rolling Out Your Killer QuickBase App
Finish Strong -- Successfully Rolling Out Your Killer QuickBase AppFinish Strong -- Successfully Rolling Out Your Killer QuickBase App
Finish Strong -- Successfully Rolling Out Your Killer QuickBase AppQuickBase, Inc.
 
Mail Merge with Lotus Notes
Mail Merge with Lotus NotesMail Merge with Lotus Notes
Mail Merge with Lotus NotesSWING Software
 
ML, Statistics, and Spark with Databricks for Maximizing Revenue in a Delayed...
ML, Statistics, and Spark with Databricks for Maximizing Revenue in a Delayed...ML, Statistics, and Spark with Databricks for Maximizing Revenue in a Delayed...
ML, Statistics, and Spark with Databricks for Maximizing Revenue in a Delayed...Databricks
 
Mail Merge with Lotus Notes
Mail Merge with Lotus NotesMail Merge with Lotus Notes
Mail Merge with Lotus Notesdjakelic
 
Link your HTML Form to Google Sheet in just 3 Steps.pdf
Link your HTML Form to Google Sheet in just 3 Steps.pdfLink your HTML Form to Google Sheet in just 3 Steps.pdf
Link your HTML Form to Google Sheet in just 3 Steps.pdfBe Problem Solver
 
SharePoint 2013 Workflow from K2
SharePoint 2013 Workflow from K2SharePoint 2013 Workflow from K2
SharePoint 2013 Workflow from K2K2
 

Similar to Modular forms in SilverStripe 3 (20)

Data analysis with Postgres and Power BI
Data analysis with Postgres and Power BIData analysis with Postgres and Power BI
Data analysis with Postgres and Power BI
 
PDF in Lotus Notes applications
PDF in Lotus Notes applicationsPDF in Lotus Notes applications
PDF in Lotus Notes applications
 
Lecture 1
Lecture 1Lecture 1
Lecture 1
 
Managing requirements with user stories
Managing requirements with user storiesManaging requirements with user stories
Managing requirements with user stories
 
Industrail training report on website design and development
Industrail training report on website design and developmentIndustrail training report on website design and development
Industrail training report on website design and development
 
aCtive Collabs in Quick Review
aCtive Collabs in Quick ReviewaCtive Collabs in Quick Review
aCtive Collabs in Quick Review
 
Workday Integration Online Training.pdf
Workday Integration Online Training.pdfWorkday Integration Online Training.pdf
Workday Integration Online Training.pdf
 
Intuit Quickbase Empower 2015 - Finish Strong: SUCCESSFULLLY ROLLING OUT YOUR...
Intuit Quickbase Empower 2015 - Finish Strong: SUCCESSFULLLY ROLLING OUT YOUR...Intuit Quickbase Empower 2015 - Finish Strong: SUCCESSFULLLY ROLLING OUT YOUR...
Intuit Quickbase Empower 2015 - Finish Strong: SUCCESSFULLLY ROLLING OUT YOUR...
 
Web Development and Design Final ProjectBefore you begin the p.docx
Web Development and Design Final ProjectBefore you begin the p.docxWeb Development and Design Final ProjectBefore you begin the p.docx
Web Development and Design Final ProjectBefore you begin the p.docx
 
MuleSoftMeetup-B2BIntegrations_using_MuleSoft
MuleSoftMeetup-B2BIntegrations_using_MuleSoftMuleSoftMeetup-B2BIntegrations_using_MuleSoft
MuleSoftMeetup-B2BIntegrations_using_MuleSoft
 
Finish Strong -- Successfully Rolling Out Your Killer QuickBase App
Finish Strong -- Successfully Rolling Out Your Killer QuickBase AppFinish Strong -- Successfully Rolling Out Your Killer QuickBase App
Finish Strong -- Successfully Rolling Out Your Killer QuickBase App
 
SharePoint 2013 Workflows
SharePoint 2013 WorkflowsSharePoint 2013 Workflows
SharePoint 2013 Workflows
 
Mail Merge with Lotus Notes
Mail Merge with Lotus NotesMail Merge with Lotus Notes
Mail Merge with Lotus Notes
 
Benchmarking new
Benchmarking newBenchmarking new
Benchmarking new
 
Workflow for XPages
Workflow for XPagesWorkflow for XPages
Workflow for XPages
 
ML, Statistics, and Spark with Databricks for Maximizing Revenue in a Delayed...
ML, Statistics, and Spark with Databricks for Maximizing Revenue in a Delayed...ML, Statistics, and Spark with Databricks for Maximizing Revenue in a Delayed...
ML, Statistics, and Spark with Databricks for Maximizing Revenue in a Delayed...
 
Mail Merge with Lotus Notes
Mail Merge with Lotus NotesMail Merge with Lotus Notes
Mail Merge with Lotus Notes
 
Link your HTML Form to Google Sheet in just 3 Steps.pdf
Link your HTML Form to Google Sheet in just 3 Steps.pdfLink your HTML Form to Google Sheet in just 3 Steps.pdf
Link your HTML Form to Google Sheet in just 3 Steps.pdf
 
SharePoint 2013 Workflow from K2
SharePoint 2013 Workflow from K2SharePoint 2013 Workflow from K2
SharePoint 2013 Workflow from K2
 
SAP Adobe forms
SAP Adobe formsSAP Adobe forms
SAP Adobe forms
 

Recently uploaded

Unveiling the Future: Sylius 2.0 New Features
Unveiling the Future: Sylius 2.0 New FeaturesUnveiling the Future: Sylius 2.0 New Features
Unveiling the Future: Sylius 2.0 New FeaturesŁukasz Chruściel
 
Implementing Zero Trust strategy with Azure
Implementing Zero Trust strategy with AzureImplementing Zero Trust strategy with Azure
Implementing Zero Trust strategy with AzureDinusha Kumarasiri
 
英国UN学位证,北安普顿大学毕业证书1:1制作
英国UN学位证,北安普顿大学毕业证书1:1制作英国UN学位证,北安普顿大学毕业证书1:1制作
英国UN学位证,北安普顿大学毕业证书1:1制作qr0udbr0
 
Cyber security and its impact on E commerce
Cyber security and its impact on E commerceCyber security and its impact on E commerce
Cyber security and its impact on E commercemanigoyal112
 
Global Identity Enrolment and Verification Pro Solution - Cizo Technology Ser...
Global Identity Enrolment and Verification Pro Solution - Cizo Technology Ser...Global Identity Enrolment and Verification Pro Solution - Cizo Technology Ser...
Global Identity Enrolment and Verification Pro Solution - Cizo Technology Ser...Cizo Technology Services
 
Ahmed Motair CV April 2024 (Senior SW Developer)
Ahmed Motair CV April 2024 (Senior SW Developer)Ahmed Motair CV April 2024 (Senior SW Developer)
Ahmed Motair CV April 2024 (Senior SW Developer)Ahmed Mater
 
Comparing Linux OS Image Update Models - EOSS 2024.pdf
Comparing Linux OS Image Update Models - EOSS 2024.pdfComparing Linux OS Image Update Models - EOSS 2024.pdf
Comparing Linux OS Image Update Models - EOSS 2024.pdfDrew Moseley
 
Call Us🔝>༒+91-9711147426⇛Call In girls karol bagh (Delhi)
Call Us🔝>༒+91-9711147426⇛Call In girls karol bagh (Delhi)Call Us🔝>༒+91-9711147426⇛Call In girls karol bagh (Delhi)
Call Us🔝>༒+91-9711147426⇛Call In girls karol bagh (Delhi)jennyeacort
 
Software Project Health Check: Best Practices and Techniques for Your Product...
Software Project Health Check: Best Practices and Techniques for Your Product...Software Project Health Check: Best Practices and Techniques for Your Product...
Software Project Health Check: Best Practices and Techniques for Your Product...Velvetech LLC
 
React Server Component in Next.js by Hanief Utama
React Server Component in Next.js by Hanief UtamaReact Server Component in Next.js by Hanief Utama
React Server Component in Next.js by Hanief UtamaHanief Utama
 
Taming Distributed Systems: Key Insights from Wix's Large-Scale Experience - ...
Taming Distributed Systems: Key Insights from Wix's Large-Scale Experience - ...Taming Distributed Systems: Key Insights from Wix's Large-Scale Experience - ...
Taming Distributed Systems: Key Insights from Wix's Large-Scale Experience - ...Natan Silnitsky
 
A healthy diet for your Java application Devoxx France.pdf
A healthy diet for your Java application Devoxx France.pdfA healthy diet for your Java application Devoxx France.pdf
A healthy diet for your Java application Devoxx France.pdfMarharyta Nedzelska
 
Balasore Best It Company|| Top 10 IT Company || Balasore Software company Odisha
Balasore Best It Company|| Top 10 IT Company || Balasore Software company OdishaBalasore Best It Company|| Top 10 IT Company || Balasore Software company Odisha
Balasore Best It Company|| Top 10 IT Company || Balasore Software company Odishasmiwainfosol
 
Intelligent Home Wi-Fi Solutions | ThinkPalm
Intelligent Home Wi-Fi Solutions | ThinkPalmIntelligent Home Wi-Fi Solutions | ThinkPalm
Intelligent Home Wi-Fi Solutions | ThinkPalmSujith Sukumaran
 
Maximizing Efficiency and Profitability with OnePlan’s Professional Service A...
Maximizing Efficiency and Profitability with OnePlan’s Professional Service A...Maximizing Efficiency and Profitability with OnePlan’s Professional Service A...
Maximizing Efficiency and Profitability with OnePlan’s Professional Service A...OnePlan Solutions
 
What is Advanced Excel and what are some best practices for designing and cre...
What is Advanced Excel and what are some best practices for designing and cre...What is Advanced Excel and what are some best practices for designing and cre...
What is Advanced Excel and what are some best practices for designing and cre...Technogeeks
 
Precise and Complete Requirements? An Elusive Goal
Precise and Complete Requirements? An Elusive GoalPrecise and Complete Requirements? An Elusive Goal
Precise and Complete Requirements? An Elusive GoalLionel Briand
 
SensoDat: Simulation-based Sensor Dataset of Self-driving Cars
SensoDat: Simulation-based Sensor Dataset of Self-driving CarsSensoDat: Simulation-based Sensor Dataset of Self-driving Cars
SensoDat: Simulation-based Sensor Dataset of Self-driving CarsChristian Birchler
 
PREDICTING RIVER WATER QUALITY ppt presentation
PREDICTING  RIVER  WATER QUALITY  ppt presentationPREDICTING  RIVER  WATER QUALITY  ppt presentation
PREDICTING RIVER WATER QUALITY ppt presentationvaddepallysandeep122
 

Recently uploaded (20)

Unveiling the Future: Sylius 2.0 New Features
Unveiling the Future: Sylius 2.0 New FeaturesUnveiling the Future: Sylius 2.0 New Features
Unveiling the Future: Sylius 2.0 New Features
 
Implementing Zero Trust strategy with Azure
Implementing Zero Trust strategy with AzureImplementing Zero Trust strategy with Azure
Implementing Zero Trust strategy with Azure
 
英国UN学位证,北安普顿大学毕业证书1:1制作
英国UN学位证,北安普顿大学毕业证书1:1制作英国UN学位证,北安普顿大学毕业证书1:1制作
英国UN学位证,北安普顿大学毕业证书1:1制作
 
Cyber security and its impact on E commerce
Cyber security and its impact on E commerceCyber security and its impact on E commerce
Cyber security and its impact on E commerce
 
Global Identity Enrolment and Verification Pro Solution - Cizo Technology Ser...
Global Identity Enrolment and Verification Pro Solution - Cizo Technology Ser...Global Identity Enrolment and Verification Pro Solution - Cizo Technology Ser...
Global Identity Enrolment and Verification Pro Solution - Cizo Technology Ser...
 
Ahmed Motair CV April 2024 (Senior SW Developer)
Ahmed Motair CV April 2024 (Senior SW Developer)Ahmed Motair CV April 2024 (Senior SW Developer)
Ahmed Motair CV April 2024 (Senior SW Developer)
 
Comparing Linux OS Image Update Models - EOSS 2024.pdf
Comparing Linux OS Image Update Models - EOSS 2024.pdfComparing Linux OS Image Update Models - EOSS 2024.pdf
Comparing Linux OS Image Update Models - EOSS 2024.pdf
 
Call Us🔝>༒+91-9711147426⇛Call In girls karol bagh (Delhi)
Call Us🔝>༒+91-9711147426⇛Call In girls karol bagh (Delhi)Call Us🔝>༒+91-9711147426⇛Call In girls karol bagh (Delhi)
Call Us🔝>༒+91-9711147426⇛Call In girls karol bagh (Delhi)
 
Software Project Health Check: Best Practices and Techniques for Your Product...
Software Project Health Check: Best Practices and Techniques for Your Product...Software Project Health Check: Best Practices and Techniques for Your Product...
Software Project Health Check: Best Practices and Techniques for Your Product...
 
Hot Sexy call girls in Patel Nagar🔝 9953056974 🔝 escort Service
Hot Sexy call girls in Patel Nagar🔝 9953056974 🔝 escort ServiceHot Sexy call girls in Patel Nagar🔝 9953056974 🔝 escort Service
Hot Sexy call girls in Patel Nagar🔝 9953056974 🔝 escort Service
 
React Server Component in Next.js by Hanief Utama
React Server Component in Next.js by Hanief UtamaReact Server Component in Next.js by Hanief Utama
React Server Component in Next.js by Hanief Utama
 
Taming Distributed Systems: Key Insights from Wix's Large-Scale Experience - ...
Taming Distributed Systems: Key Insights from Wix's Large-Scale Experience - ...Taming Distributed Systems: Key Insights from Wix's Large-Scale Experience - ...
Taming Distributed Systems: Key Insights from Wix's Large-Scale Experience - ...
 
A healthy diet for your Java application Devoxx France.pdf
A healthy diet for your Java application Devoxx France.pdfA healthy diet for your Java application Devoxx France.pdf
A healthy diet for your Java application Devoxx France.pdf
 
Balasore Best It Company|| Top 10 IT Company || Balasore Software company Odisha
Balasore Best It Company|| Top 10 IT Company || Balasore Software company OdishaBalasore Best It Company|| Top 10 IT Company || Balasore Software company Odisha
Balasore Best It Company|| Top 10 IT Company || Balasore Software company Odisha
 
Intelligent Home Wi-Fi Solutions | ThinkPalm
Intelligent Home Wi-Fi Solutions | ThinkPalmIntelligent Home Wi-Fi Solutions | ThinkPalm
Intelligent Home Wi-Fi Solutions | ThinkPalm
 
Maximizing Efficiency and Profitability with OnePlan’s Professional Service A...
Maximizing Efficiency and Profitability with OnePlan’s Professional Service A...Maximizing Efficiency and Profitability with OnePlan’s Professional Service A...
Maximizing Efficiency and Profitability with OnePlan’s Professional Service A...
 
What is Advanced Excel and what are some best practices for designing and cre...
What is Advanced Excel and what are some best practices for designing and cre...What is Advanced Excel and what are some best practices for designing and cre...
What is Advanced Excel and what are some best practices for designing and cre...
 
Precise and Complete Requirements? An Elusive Goal
Precise and Complete Requirements? An Elusive GoalPrecise and Complete Requirements? An Elusive Goal
Precise and Complete Requirements? An Elusive Goal
 
SensoDat: Simulation-based Sensor Dataset of Self-driving Cars
SensoDat: Simulation-based Sensor Dataset of Self-driving CarsSensoDat: Simulation-based Sensor Dataset of Self-driving Cars
SensoDat: Simulation-based Sensor Dataset of Self-driving Cars
 
PREDICTING RIVER WATER QUALITY ppt presentation
PREDICTING  RIVER  WATER QUALITY  ppt presentationPREDICTING  RIVER  WATER QUALITY  ppt presentation
PREDICTING RIVER WATER QUALITY ppt presentation
 

Modular forms in SilverStripe 3

  • 1. A modular approach to Forms 13 July 2015 • SilverStripe London • Dan Hensby
  • 2. Why modular forms? ● Keep related logic in one place ● Have a single point of truth for forms ● Form re-use is easy ● Add logic to all forms in one go ● Remove logic from your controller ● Provide a common interface for defining forms in you project
  • 3. Here we are: ● Defining an abstract class to create our common interface ● Making most constructor arguments optional ● Using internal class methods to define Fields, Actions & Validator Now we have a common API for creating forms A base form Defining an interface and API for your forms
  • 4. Here we are: ● Defining a simple contact form ● Adding fields ● Setting the button label ● Making the fields required ● Defining the submission handler `doSubmit` ● Using `Config` to assign defaults for the outgoing email Creating a contact form
  • 5. We’ve defined a simple Email Template for contact form submissions Create a simple email template We’ve all done this before
  • 6. Here we have: ● Added `Form` and `success` as “allowed action” ● Defined a `Form` method to create the `ContactForm` ● Defined a `success` action on the controller (and template) We have removed the logic around the `ContactForm` from the controller Set up the controller
  • 7. ● Since 3.0 styling form fields has become simple ● We can add custom template files to override the markup ● We can work around default behaviour of duplicated classnames ● In 3.2 we can add default class names to forms and fields Styling the front end form
  • 8. ● Using BEM to write clear CSS ● Block Element Modifier ● .block .block__element .block__element--modifier ● Best used with a CSS pre-processor ● Solves many common issues with CSS on (large) projects Resources: ● https://en.bem.info/ ● http://cssguidelin.es/ Creating simple CSS
  • 9. Thank you! Code here: http://bit.ly/ss3forms Twitter/GitHub/etc: @dhensby