SlideShare a Scribd company logo
1 of 32
Advanced Custom Fields
Flexible layouts and other cool stuff!
by Kirsty Burgoine
www.kirstyburgoine.co.uk
twitter.com/kirstyburgoine
info@kirstyburgoine.co.uk
Who am I?
• Web developer / designer
• Run my own business in
Shrewsbury / Shropshire
• Organiser of Shropgeek which
includes:
- Socials
- Rebellion (mini conferences)
- (R)Evolution (annual
conference)
• and I ‘~ grin!’ alot
A little about Advanced Custom Fields ...
General Settings
• Adding the group and field
Label, Name, Type,
Conditional Logic
• Location
Show on specific pages,
posts, taxonomy etc.
• Options
Position, Style, hide on
screen
Creating Custom Fields
The Flexible Content field
What you will need:
• Flexible Content Field
• Repeater Field
Both are premium fields and cost $25.00 AUD each.
http://www.advancedcustomfields.com/add-ons/
Creating the Flexible Content field
And here’s one I made earlier....
Editing the Fields
• Layouts - This will display in popup when editing the page
• Create sub field within the layout that could be used for Flexible
content.
• For multiple columns set as a Repeater Field
• Add repeater fields inside the sub field
• Set a maximum number of rows. This will make your CSS easier to
manage.
• For more layouts, click Add New under each layout and repeat
process
Adding flexible content to the page
And here’s one I made earlier....
Building the flexible content into our theme
Step 1
Create the main page template: flexible-content.php
In that template create a new loop for the flexible content within the
main loop using has_field()
The page template
Step 2
Create the template part for each layout.
content-flexible-text.php
content-flexible-carousel.php
Careful to use the name of the layout i.e. text, carousel
We can now automatically pull in the right type of content based on the
selection made in the admin panel
The template part
Example used here is content-flexible-text.php
First of all we need to get all of the content from the Text Flexible
Content Field
$columns is a repeater field so we initiate a new loop and get all of the
content from each sub field
oEmbed Tip: Make sure video links are not hyperlinked!
The template part
Then display the content:
The template part - CSS
The template part - CSS
Step 3
Setup the columns to create their class dynamically
$columns is our repeater field. $text_count counts the number of fields
created.
We originally limited our columns to 4 when creating the flexible
content field so we know the classes created here will be .span1,
.span2, .span3, .span4
The template part - CSS
The template part - CSS
Making the columns responsive:
As well as the CSS I also used fitvids.js to make the videos responsive
Google Maps & the Locations field
What you will need:
•Location Field
•Knowledge of Google Maps API v3
The location field is a free add on.
http://www.advancedcustomfields.com/add-ons/
Creating the Location field
And here’s one I made earlier....
Creating the locations
Create a new
page for each
separate
location.
The location field
group is set to
only show on
child pages of
the main
locations page.
Displaying each location on the page
Step 1
Add the google map container <div> to content-page.php
In this case the post parent is our main locations page.
The container has been added outside of .content-entry to avoid any
distortion caused by the CSS .content-entry img { max-width: 100%; }
Displaying each location on the page
Step 2
Within the loop get the locations field using get_field();
Add the javascript for Google maps
Displaying each location on the page
The location field is an array that allows you to use the original address
inputted and the coordinates returned.
In the example given, we used $post_code[‘coordinates’] in the
Google maps javascript.
Notice there is also a custom image for the map marker here.
Displaying all locations on one map
Step 1
Create the main page template: locations-main.php
Step 2
Add the google map container <div> to the page
Step 3
Create the map and add the markers ...
Displaying all locations on one map
Step 3 continued.
Create a new loop
that finds all of the
location
coordinates.
This loop then
needs to insert all
of the information
into an array called
$marker for later
use in a our
javascript.
Displaying all locations on one map
Step 3 continued.
The Javascript.
This example shows how
each marker is created
and where it is placed.
Full code can be found in
locations-main.php
Dealing with Images
What you will need:
•Gallery Field
The gallery field is a premium add on and costs $25.00 AUD.
http://www.advancedcustomfields.com/add-ons/
Dealing with Images
And here’s one I made earlier....
Images and the Gallery field type
Image Return
Values
The Image
Object array
returns a lot of
information we
can use:
Gallery field type
Gallery field automatically stores all information about each image in an
Image Object.
This allows us to do some cool stuff with them.
Creating a gallery of images
Create the flexible content field for the gallery.
Here’s one I made earlier ...
Creating a gallery of images
Create the template part for the layout. This will be a flexible layout as
well.
content-flexible-carousel.php
Once created, get all of the content from the flexible content carousel
fields
$carousel_images is an array so we need to create a foreach loop to
access all of the information
Creating a gallery of images
To create the carousel I used flexslider 2 from Woothemes:
http://flexslider.woothemes.com/index.html
Thank you.
Credits and Resources
• www.advancedcustomfields.com
• fitvidsjs.com/
• flexslider.woothemes.com/index.ht
ml
• placekitten.com
• www.kirstyburgoine.co.uk
• twitter.com/kirstyburgoine
• info@kirstyburgoine.co.uk
All theme files can be found on github at:
• https://github.com/kirstyburgoine/wcuk20
13

More Related Content

Similar to WCUK2013 - ACF Flexible Content and other cool stuff

Make Meta Boxes Great Again
Make Meta Boxes Great AgainMake Meta Boxes Great Again
Make Meta Boxes Great AgainLinchpin
 
Creative i media r085
Creative i media r085Creative i media r085
Creative i media r085Jimmy Edwards
 
Page object from the ground up.ppt
Page object from the ground up.pptPage object from the ground up.ppt
Page object from the ground up.pptJoseph Beale
 
Page object from the ground up by Joe Beale
Page object from the ground up by Joe BealePage object from the ground up by Joe Beale
Page object from the ground up by Joe BealeQA or the Highway
 
Web development basics (Part-2)
Web development basics (Part-2)Web development basics (Part-2)
Web development basics (Part-2)Rajat Pratap Singh
 
14 asp.net session20
14 asp.net session2014 asp.net session20
14 asp.net session20Vivek chan
 
The New CSS Layout - Dutch PHP Conference
The New CSS Layout - Dutch PHP ConferenceThe New CSS Layout - Dutch PHP Conference
The New CSS Layout - Dutch PHP ConferenceRachel Andrew
 
Building Potent WordPress Websites
Building Potent WordPress WebsitesBuilding Potent WordPress Websites
Building Potent WordPress WebsitesKyle Cearley
 
Make Meta Boxes Great Again
Make Meta Boxes Great AgainMake Meta Boxes Great Again
Make Meta Boxes Great AgainNate Allen
 
Wordpress beyond blogging
Wordpress beyond bloggingWordpress beyond blogging
Wordpress beyond bloggingJulien Minguely
 
Cis363 a all ilabs devry university
Cis363 a all ilabs devry universityCis363 a all ilabs devry university
Cis363 a all ilabs devry universityCIS363A
 
Cis363 all i labs devry university
Cis363 all i labs devry universityCis363 all i labs devry university
Cis363 all i labs devry universityjkkjhdy798iyi
 
Cis363 all i labs devry university
Cis363 all i labs devry universityCis363 all i labs devry university
Cis363 all i labs devry universityCIS363A
 
Cis363 a all ilabs devry university
Cis363 a all ilabs devry universityCis363 a all ilabs devry university
Cis363 a all ilabs devry universityCIS363A
 
Creating a web gallery lightbox2 final
Creating a web gallery lightbox2 finalCreating a web gallery lightbox2 final
Creating a web gallery lightbox2 finalDaniel Downs
 
Skroutz redesign - How to approach card-based design & SASS content - specifi...
Skroutz redesign - How to approach card-based design & SASS content - specifi...Skroutz redesign - How to approach card-based design & SASS content - specifi...
Skroutz redesign - How to approach card-based design & SASS content - specifi...Skroutz S.A.
 
Sass Essentials at Mobile Camp LA
Sass Essentials at Mobile Camp LASass Essentials at Mobile Camp LA
Sass Essentials at Mobile Camp LAJake Johnson
 
From Zero to Hero – Web Performance
From Zero to Hero – Web PerformanceFrom Zero to Hero – Web Performance
From Zero to Hero – Web PerformanceSebastian Springer
 

Similar to WCUK2013 - ACF Flexible Content and other cool stuff (20)

Make Meta Boxes Great Again
Make Meta Boxes Great AgainMake Meta Boxes Great Again
Make Meta Boxes Great Again
 
Creative i media r085
Creative i media r085Creative i media r085
Creative i media r085
 
Page object from the ground up.ppt
Page object from the ground up.pptPage object from the ground up.ppt
Page object from the ground up.ppt
 
Page object from the ground up by Joe Beale
Page object from the ground up by Joe BealePage object from the ground up by Joe Beale
Page object from the ground up by Joe Beale
 
Web development basics (Part-2)
Web development basics (Part-2)Web development basics (Part-2)
Web development basics (Part-2)
 
AD0-E116-demo.pdf
AD0-E116-demo.pdfAD0-E116-demo.pdf
AD0-E116-demo.pdf
 
14 asp.net session20
14 asp.net session2014 asp.net session20
14 asp.net session20
 
HTML and CSS.pptx
HTML and CSS.pptxHTML and CSS.pptx
HTML and CSS.pptx
 
The New CSS Layout - Dutch PHP Conference
The New CSS Layout - Dutch PHP ConferenceThe New CSS Layout - Dutch PHP Conference
The New CSS Layout - Dutch PHP Conference
 
Building Potent WordPress Websites
Building Potent WordPress WebsitesBuilding Potent WordPress Websites
Building Potent WordPress Websites
 
Make Meta Boxes Great Again
Make Meta Boxes Great AgainMake Meta Boxes Great Again
Make Meta Boxes Great Again
 
Wordpress beyond blogging
Wordpress beyond bloggingWordpress beyond blogging
Wordpress beyond blogging
 
Cis363 a all ilabs devry university
Cis363 a all ilabs devry universityCis363 a all ilabs devry university
Cis363 a all ilabs devry university
 
Cis363 all i labs devry university
Cis363 all i labs devry universityCis363 all i labs devry university
Cis363 all i labs devry university
 
Cis363 all i labs devry university
Cis363 all i labs devry universityCis363 all i labs devry university
Cis363 all i labs devry university
 
Cis363 a all ilabs devry university
Cis363 a all ilabs devry universityCis363 a all ilabs devry university
Cis363 a all ilabs devry university
 
Creating a web gallery lightbox2 final
Creating a web gallery lightbox2 finalCreating a web gallery lightbox2 final
Creating a web gallery lightbox2 final
 
Skroutz redesign - How to approach card-based design & SASS content - specifi...
Skroutz redesign - How to approach card-based design & SASS content - specifi...Skroutz redesign - How to approach card-based design & SASS content - specifi...
Skroutz redesign - How to approach card-based design & SASS content - specifi...
 
Sass Essentials at Mobile Camp LA
Sass Essentials at Mobile Camp LASass Essentials at Mobile Camp LA
Sass Essentials at Mobile Camp LA
 
From Zero to Hero – Web Performance
From Zero to Hero – Web PerformanceFrom Zero to Hero – Web Performance
From Zero to Hero – Web Performance
 

More from Kirsty Burgoine

Smile - Its never that bad! Mastering the sales meeting without turning to th...
Smile - Its never that bad! Mastering the sales meeting without turning to th...Smile - Its never that bad! Mastering the sales meeting without turning to th...
Smile - Its never that bad! Mastering the sales meeting without turning to th...Kirsty Burgoine
 
The dark art of sales meetings - WordCamp Bournemouth Version
The dark art of sales meetings - WordCamp Bournemouth VersionThe dark art of sales meetings - WordCamp Bournemouth Version
The dark art of sales meetings - WordCamp Bournemouth VersionKirsty Burgoine
 
Question of deliverables and other such stuff
Question of deliverables and other such stuffQuestion of deliverables and other such stuff
Question of deliverables and other such stuffKirsty Burgoine
 
Speak the Web - Liverpool 24.07.13
Speak the Web - Liverpool 24.07.13Speak the Web - Liverpool 24.07.13
Speak the Web - Liverpool 24.07.13Kirsty Burgoine
 
Working with designers that dont code
Working with designers that dont codeWorking with designers that dont code
Working with designers that dont codeKirsty Burgoine
 

More from Kirsty Burgoine (7)

Wpldn july2015 usb
Wpldn july2015 usbWpldn july2015 usb
Wpldn july2015 usb
 
WC Birmingham 2015
WC Birmingham 2015WC Birmingham 2015
WC Birmingham 2015
 
Smile - Its never that bad! Mastering the sales meeting without turning to th...
Smile - Its never that bad! Mastering the sales meeting without turning to th...Smile - Its never that bad! Mastering the sales meeting without turning to th...
Smile - Its never that bad! Mastering the sales meeting without turning to th...
 
The dark art of sales meetings - WordCamp Bournemouth Version
The dark art of sales meetings - WordCamp Bournemouth VersionThe dark art of sales meetings - WordCamp Bournemouth Version
The dark art of sales meetings - WordCamp Bournemouth Version
 
Question of deliverables and other such stuff
Question of deliverables and other such stuffQuestion of deliverables and other such stuff
Question of deliverables and other such stuff
 
Speak the Web - Liverpool 24.07.13
Speak the Web - Liverpool 24.07.13Speak the Web - Liverpool 24.07.13
Speak the Web - Liverpool 24.07.13
 
Working with designers that dont code
Working with designers that dont codeWorking with designers that dont code
Working with designers that dont code
 

Recently uploaded

WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure serviceWhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure servicePooja Nehwal
 
Google AI Hackathon: LLM based Evaluator for RAG
Google AI Hackathon: LLM based Evaluator for RAGGoogle AI Hackathon: LLM based Evaluator for RAG
Google AI Hackathon: LLM based Evaluator for RAGSujit Pal
 
Salesforce Community Group Quito, Salesforce 101
Salesforce Community Group Quito, Salesforce 101Salesforce Community Group Quito, Salesforce 101
Salesforce Community Group Quito, Salesforce 101Paola De la Torre
 
Maximizing Board Effectiveness 2024 Webinar.pptx
Maximizing Board Effectiveness 2024 Webinar.pptxMaximizing Board Effectiveness 2024 Webinar.pptx
Maximizing Board Effectiveness 2024 Webinar.pptxOnBoard
 
Breaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path MountBreaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path MountPuma Security, LLC
 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerThousandEyes
 
Presentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreterPresentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreternaman860154
 
Swan(sea) Song – personal research during my six years at Swansea ... and bey...
Swan(sea) Song – personal research during my six years at Swansea ... and bey...Swan(sea) Song – personal research during my six years at Swansea ... and bey...
Swan(sea) Song – personal research during my six years at Swansea ... and bey...Alan Dix
 
A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)Gabriella Davis
 
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhi
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | DelhiFULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhi
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhisoniya singh
 
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
08448380779 Call Girls In Diplomatic Enclave Women Seeking MenDelhi Call girls
 
Enhancing Worker Digital Experience: A Hands-on Workshop for Partners
Enhancing Worker Digital Experience: A Hands-on Workshop for PartnersEnhancing Worker Digital Experience: A Hands-on Workshop for Partners
Enhancing Worker Digital Experience: A Hands-on Workshop for PartnersThousandEyes
 
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Drew Madelung
 
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...Igalia
 
Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365
Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365
Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 3652toLead Limited
 
Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonAnna Loughnan Colquhoun
 
[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdfhans926745
 
08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking MenDelhi Call girls
 
Unblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesUnblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesSinan KOZAK
 
Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...
Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...
Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...gurkirankumar98700
 

Recently uploaded (20)

WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure serviceWhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
 
Google AI Hackathon: LLM based Evaluator for RAG
Google AI Hackathon: LLM based Evaluator for RAGGoogle AI Hackathon: LLM based Evaluator for RAG
Google AI Hackathon: LLM based Evaluator for RAG
 
Salesforce Community Group Quito, Salesforce 101
Salesforce Community Group Quito, Salesforce 101Salesforce Community Group Quito, Salesforce 101
Salesforce Community Group Quito, Salesforce 101
 
Maximizing Board Effectiveness 2024 Webinar.pptx
Maximizing Board Effectiveness 2024 Webinar.pptxMaximizing Board Effectiveness 2024 Webinar.pptx
Maximizing Board Effectiveness 2024 Webinar.pptx
 
Breaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path MountBreaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path Mount
 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected Worker
 
Presentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreterPresentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreter
 
Swan(sea) Song – personal research during my six years at Swansea ... and bey...
Swan(sea) Song – personal research during my six years at Swansea ... and bey...Swan(sea) Song – personal research during my six years at Swansea ... and bey...
Swan(sea) Song – personal research during my six years at Swansea ... and bey...
 
A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)
 
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhi
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | DelhiFULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhi
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhi
 
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
 
Enhancing Worker Digital Experience: A Hands-on Workshop for Partners
Enhancing Worker Digital Experience: A Hands-on Workshop for PartnersEnhancing Worker Digital Experience: A Hands-on Workshop for Partners
Enhancing Worker Digital Experience: A Hands-on Workshop for Partners
 
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
 
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
 
Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365
Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365
Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365
 
Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt Robison
 
[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf
 
08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men
 
Unblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesUnblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen Frames
 
Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...
Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...
Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...
 

WCUK2013 - ACF Flexible Content and other cool stuff

  • 1. Advanced Custom Fields Flexible layouts and other cool stuff! by Kirsty Burgoine www.kirstyburgoine.co.uk twitter.com/kirstyburgoine info@kirstyburgoine.co.uk
  • 2. Who am I? • Web developer / designer • Run my own business in Shrewsbury / Shropshire • Organiser of Shropgeek which includes: - Socials - Rebellion (mini conferences) - (R)Evolution (annual conference) • and I ‘~ grin!’ alot
  • 3. A little about Advanced Custom Fields ...
  • 4. General Settings • Adding the group and field Label, Name, Type, Conditional Logic • Location Show on specific pages, posts, taxonomy etc. • Options Position, Style, hide on screen Creating Custom Fields
  • 5. The Flexible Content field What you will need: • Flexible Content Field • Repeater Field Both are premium fields and cost $25.00 AUD each. http://www.advancedcustomfields.com/add-ons/
  • 6. Creating the Flexible Content field And here’s one I made earlier....
  • 7. Editing the Fields • Layouts - This will display in popup when editing the page • Create sub field within the layout that could be used for Flexible content. • For multiple columns set as a Repeater Field • Add repeater fields inside the sub field • Set a maximum number of rows. This will make your CSS easier to manage. • For more layouts, click Add New under each layout and repeat process
  • 8. Adding flexible content to the page And here’s one I made earlier....
  • 9. Building the flexible content into our theme Step 1 Create the main page template: flexible-content.php In that template create a new loop for the flexible content within the main loop using has_field()
  • 10. The page template Step 2 Create the template part for each layout. content-flexible-text.php content-flexible-carousel.php Careful to use the name of the layout i.e. text, carousel We can now automatically pull in the right type of content based on the selection made in the admin panel
  • 11. The template part Example used here is content-flexible-text.php First of all we need to get all of the content from the Text Flexible Content Field $columns is a repeater field so we initiate a new loop and get all of the content from each sub field oEmbed Tip: Make sure video links are not hyperlinked!
  • 12. The template part Then display the content:
  • 13. The template part - CSS The template part - CSS Step 3 Setup the columns to create their class dynamically $columns is our repeater field. $text_count counts the number of fields created. We originally limited our columns to 4 when creating the flexible content field so we know the classes created here will be .span1, .span2, .span3, .span4
  • 14. The template part - CSS The template part - CSS Making the columns responsive: As well as the CSS I also used fitvids.js to make the videos responsive
  • 15. Google Maps & the Locations field What you will need: •Location Field •Knowledge of Google Maps API v3 The location field is a free add on. http://www.advancedcustomfields.com/add-ons/
  • 16. Creating the Location field And here’s one I made earlier....
  • 17. Creating the locations Create a new page for each separate location. The location field group is set to only show on child pages of the main locations page.
  • 18. Displaying each location on the page Step 1 Add the google map container <div> to content-page.php In this case the post parent is our main locations page. The container has been added outside of .content-entry to avoid any distortion caused by the CSS .content-entry img { max-width: 100%; }
  • 19. Displaying each location on the page Step 2 Within the loop get the locations field using get_field(); Add the javascript for Google maps
  • 20. Displaying each location on the page The location field is an array that allows you to use the original address inputted and the coordinates returned. In the example given, we used $post_code[‘coordinates’] in the Google maps javascript. Notice there is also a custom image for the map marker here.
  • 21. Displaying all locations on one map Step 1 Create the main page template: locations-main.php Step 2 Add the google map container <div> to the page Step 3 Create the map and add the markers ...
  • 22. Displaying all locations on one map Step 3 continued. Create a new loop that finds all of the location coordinates. This loop then needs to insert all of the information into an array called $marker for later use in a our javascript.
  • 23. Displaying all locations on one map Step 3 continued. The Javascript. This example shows how each marker is created and where it is placed. Full code can be found in locations-main.php
  • 24. Dealing with Images What you will need: •Gallery Field The gallery field is a premium add on and costs $25.00 AUD. http://www.advancedcustomfields.com/add-ons/
  • 25. Dealing with Images And here’s one I made earlier....
  • 26. Images and the Gallery field type Image Return Values The Image Object array returns a lot of information we can use:
  • 27. Gallery field type Gallery field automatically stores all information about each image in an Image Object. This allows us to do some cool stuff with them.
  • 28. Creating a gallery of images Create the flexible content field for the gallery. Here’s one I made earlier ...
  • 29. Creating a gallery of images Create the template part for the layout. This will be a flexible layout as well. content-flexible-carousel.php Once created, get all of the content from the flexible content carousel fields $carousel_images is an array so we need to create a foreach loop to access all of the information
  • 30. Creating a gallery of images To create the carousel I used flexslider 2 from Woothemes: http://flexslider.woothemes.com/index.html
  • 32. Credits and Resources • www.advancedcustomfields.com • fitvidsjs.com/ • flexslider.woothemes.com/index.ht ml • placekitten.com • www.kirstyburgoine.co.uk • twitter.com/kirstyburgoine • info@kirstyburgoine.co.uk All theme files can be found on github at: • https://github.com/kirstyburgoine/wcuk20 13

Editor's Notes

  1. Started off as Magic Fields Presume a certain amount of knowledge about building themes and creating templates