Drupal Beginner Track #4 Intro to Drupal 7 Theming

Transcription

Drupal Beginner Track #4 Intro to Drupal 7 Theming
Drupal Theming
“
A theme is a collection of files that define
the presentation layer.
https://www.drupal.org/node/171194
Theme Overview
What are the different options when it
comes to theming?
contrib
Free, open source!
purchased
Improved design
YMMV
How to pick a theme?
▧
▧
▧
▧
▧
▧
▧
▧
How many reported installs?
Do they have a stable release?
Who wrote it?
Good documentation?
Any boobytraps in the issue queue?
When was the last commit?
Is it RESPONSIVE?
HOW DOES IT LOOK?
Custom
From scratch
From a base theme
Base Themes
LAB 1
Find a contrib theme & install it on your site
http://www.drupal.org
LAB 1
1. GO: http://www.drupal.org
2. Navigate to:
Download & Extend > Most Installed Themes
3. Pick a theme (not a base theme) & download the zip
4. Unzip the theme
5. Copy the theme folder to sites/all/themes/contrib
6. Import site into Acquia ADD
○ Select the folder you copied to your laptop
○ Import the database from SANDcamp2016.sql
7. Log in as admin/sandcamp2016
8. Enable the DrupalAce theme
& set as default under ‘Appearance’
Anatomy of a Theme
Stuff you find inside a theme
[theme_name].info
css/
js/
img/
templates/
template.php
Theme info
Configuration
settings
Defined
Regions
CSS
JavaScript
Other Stuff
plugins
settings
etc.
LAB 2
Create your own custom subtheme
LAB 2
1. Download & Install ‘Bootstrap’ base theme
https://www.drupal.org/project/bootstrap
2. Create your subtheme
Copy
/sites/all/themes/bootstrap/bootstrap_subtheme to
/sites/all/themes
3. Rename the bootstrap_subtheme folder to mytheme
4. In mytheme folder, rename bootstrap_subtheme.info.
starterkit to mytheme.info
5. Customize mytheme.info
Set ‘name’ to ‘My Custom Bootstrap Sub-theme’
Set ‘description’ to ‘My first custom theme’
6. In your browser, go to ‘Appearances’ and set
mytheme to “enable & set default”
TPL files
www.drupal.org/node/1089656
▧
▧
▧
▧
▧
modules\system\html.tpl.php
modules\system\page.tpl.php
modules\system\region.tpl.php
modules\node\node.tpl.php
modules\block\block.tpl.php
Search for *.tpl.php
in your site installation folder
and take a look at a few of them
Putting
business logic
code in the
*.tpl.php
▧
▧
▧
▧
▧
TPL File Precedence
page--node--[nid].tpl.php
page--[node-name].tpl.php
page--node.tpl.php
page--front.tpl.php (if front page)
page.tpl.php
▧
▧
▧
▧
▧
TPL File Precedence
page--node--[nid].tpl.php
page--[node-name].tpl.php
page--node.tpl.php
page--front.tpl.php (if front page)
page.tpl.php
Customizing A View using template suggestions
Advanced > Theme: Information
LAB 3
Create your own custom region
LAB 3 - Add a custom region to theme
1. Define the new region in mytheme.info
regions[content_footer] = 'Content footer'
2. Copy
.../bootstrap/theme/system/page.tpl.php to
.../mytheme/templates/page.tpl.php
3. Print the new region content in ...
/mytheme/templates/page.tpl.php
After line 155:
<?php print render($page['content']); ?>
Add these three lines of code:
<?php if (!empty($page['content_footer'])): ?>
<?php print render($page['content_footer']); ?>
<?php endif; ?>
4. Flush all caches!!
5. Create a new custom block
6. Place it in the new ‘Content Footer’ region
LAB 4
Customize your CSS!
LAB 4 - Add CSS
1. Open .../mytheme/css/style.css
2. Add CSS rule:
body {
background-color: #ffa500;
}
3. In your browser, RELOAD
LAB 5
Theme a block
LAB 5 - theme a specific block
1. Create a new custom content block
Structure > Blocks > Add Block
Block title: leave blank (shown to user)
Block description: My Custom Block (for admin)
Body block: This is my custom block
2. Place block in the Footer region
Structure > Blocks
3. Use a browser inspector to get the CSS ID of the block.
It will be something like block-block-n
4. Open .../mytheme/css/style.css
Add a CSS rule:
#block-block-2 {
background-color: #FFFF00;
}
5. In your browser, RELOAD
LAB 5 - block-block-2
1. Create a new custom content block
Structure > Blocks > Add Block
Block title: leave blank (shown to user)
Block description: My Custom Block (for admin)
Body block: This is my custom block
2. Place block in Right Sidebar (Secondary)
Structure > Blocks
3. Use a browser inspector to get the CSS ID of the block.
It will be something like block-block-n
4. Open .../mytheme/css/style.css
Add a CSS rule:
#block-block-1 {
background-color: #FFFF00;
}
5. In your browser, RELOAD
DEMO 1
Automatically add “Copyright
2016” to the footer region
where the year is generated
dynamically as opposed to
being static text.
DEMO 1
1. Edit template.php in your mytheme folder
and add these lines:
function mytheme_preprocess_page(&$variables){
$variables['copyright'] =
t("Copyright @date", array('@date' => date('Y'),));;
}
2. Edit /templates/page.tpl.php in your mytheme folder
and just below this line (almost at bottom of file):
<?php print render($page['footer']); ?>
Add:
<?php if(isset($copyright)) : ?>
<?php print $copyright; ?>
<?php endif; ?>
3. Flush all caches (when in doubt flush twice or more!)
DEMO 2
1. Turn on and configure Devel module with settings:
Display $page array
Rebuild the theme registry on every page load
2. Edit template.php in your mytheme folder
and add these lines
/**
* Add plus sign to all block titles in the footer region
*/
function mytheme_preprocess_block(&$variables){
//
dpm($variables['block']);
//
dpm($variables['block']->region);
if ($variables['block']->region == "footer") {
$variables['block']->subject = '-' . $variables['block']->subject;
}
//
}
dpm($variables['block']->subject);
DEMO 2
1. Turn on and configure Devel module with:
Display $page array
Rebuild the theme registry on every page load
2. Edit template.php in your mytheme folder
and add these lines (or copy from bootstrap-final)
/**
* Add plus sign to all block titles in the footer region
*/
function mytheme_preprocess_block(&$variables){
//
dpm($variables['block']);
//
dpm($variables['block']->region);
if ($variables['block']->region == "footer") {
$variables['block']->subject = '-' . $variables['block']->subject;
}
//
}
dpm($variables['block']->subject);
LAB 7
Configure for production service
LAB 6 - Configure for production
1. In Drupal Admin, go to
Configuration >
Development >
Performance
2. Turn on
a. Cache pages for anonymous users
b. Cache blocks
c. Aggregate and compress CSS files
d. Aggregate JavaScript files
Additional resources
http://meetup.com/San-Diego-Drupal-Users-Group/
https://groups.drupal.org/san-diego
https://www.drupal.org/irc
Extra Credit/Bonus
▧ CSS Injector module
▧ How to modify markup in Views
▧ Display Suite, Panes and
Paragraph modules
▧ SimplyTest.me to try out new modules
Thanks!
Any questions?
You can find me at:
@richyumul
rmy@sagetree.net