Drupal Theming

broken image


Drupal HTML5 is celebrated as a way for websites to become richer and more interactive: closing the gap on native apps with geolocation, video, games, and audio through asynchronous communication with local storage and dynamic web user interfaces. The Drupal 7 content management system (CMS) didn't ship with HTML5 support. If HTML5's technology is something you wish to integrate with your Drupal 7 website, read on for a primer on HTML5 and a guide to using HTML5 features in the CMS.

The State of HTML in Drupal 7: The Doctype

Drupal 7 shipped its release on January 5, 2011. Drupal 7's code freeze was September 1, 2009. W3C didn't propose a stable HTML5 spec recommendation until October, 2014 and much of HTML5 was still up in the air as late as 2012. Needless to say, Drupal 7 didn't ship with HTML5 as the frontend spec. Drupal 7 released instead with an XHTML 1.0 transitional document type declaration (doctype):

Fortunately, Drupal's adaptive nature as a platform means that HTML5 can be well-integrated in all key areas of the CMS.

Technically, all that needs to be done to change the doctype parameter of your Drupal website is to declare it on your first line of HTML:

Drupal theme folder structure A theme is a collection of files that define the presentation layer. You can also create one or more 'sub-themes' or variations on a theme. Adding Regions to a Theme. Plenty of great reasons to use Drupal and Drupal themes. Drupal is a free and open source platform that allows you to manage content on your website, and it's used worldwide by many websites you're probably already familiar with: it currently powers at least 2.2% of all the websites worldwide (millions and millions). That's a massive accomplishment!

This 'empty' declaration will default to HTML5 for all browsers which support it.

What is Drupal HTML5 and How Does it Work?

So what's the trouble? That seems like a pretty simple line of HTML to change, doesn't it?

Understanding XHTML/HTML Compatibility with HTML5

You're about to speak to a stranger; think of when you're traveling. You don't know whether they speak your native language or not. What's the first thing you say to them? It's probably: 'Do you speak English?' Perhaps they respond back that they do. Now, they've tuned their brain to be ready for you to say something in English. What would happen if you then started asking where the nearest bathroom was but instead added some Spanish, '¿Where is the baño?'

This is how a doctype declaration works for HTML. The browser and the server are agreeing on what sort of language they're going to use with each other. This doesn't 'translate' all the HTML that you're actually using though: you still need to update tags to meet their HTML5 specifications. If not, you might be throwing some Spanish into the middle of your HTML and hoping the browser will make a guess as to what you mean.

Deprecated HTML Tag Elements in HTML5

The good news is that most HTML tags won't need to be changed. The tags you use in old HTML/XHTML will still work, they'll just lack the additional features or context that HTML5 elements offer. (You're not using a tag right?)

Some HTML tags have been deprecated in HTML5:

Drupal Theming
  • This is a searchable index. Enter search keywords:
  • </li><li><s></li><li><strike></li><li><tt></li><li><u></li></ul><p>If you're still using any of these tags, you'll need to convert them to appropriate tags still supported. For example, <center> has been deprecated because it was used to <em>visually</em> center page elements. Visual layout is the purpose of Cascading Style Sheets (CSS). The CSS property, <em>text-align</em>, provides an option of <em>center. </em>You'd want to utilize this property and value to visually center elements on the page instead of the <center> HTML tag.</p><p>If your Drupal implementation has some inline HTML, perhaps through WYSIWYG content areas or Block content areas, you'll need to make sure no deprecated HTML tags are used.</p><h3>New HTML5 Tag Elements</h3><p>The new HTML5 elements I find myself using the most are actually semantic tags that further define classic div tags. A div is simply a block element which contains other elements (its opposite is the span which is an inline element container). Divs make up large quantities, if not most, of the tags used on any particular webpage. W3C wanted to offer further context through HTML5 to these div tags. Instead of just divs, we now have: <em>nav</em>, <em>article</em>, <em>figure</em>, <em>aside</em>, and <em>section</em> to work with. HTML5 Doctor offers an excellent flowchart to help visualize your decision as to which tag is most appropriate:</p><p>Of course, there's much more to the HTML5 spec than just these handful of new semantic tags. What's important to understand is that these new semantic tags are the <em>basis</em> of the HTML5 spec.</p><h4>Semantic Tags</h4><p>W3C defines the new semantic tag elements available within HTML5.</p><table align='center' cellspacing='1'><thead><tr><th scope='col'>Tag</th><th scope='col'>Description</th></tr></thead><tbody><tr><td><article></td><td>Defines an article in the document</td></tr><tr><td><aside></td><td>Defines content aside from the page content</td></tr><tr><td><bdi></td><td>Defines a part of text that might be formatted in a different direction from other text</td></tr><tr><td><details></td><td>Defines additional details that the user can view or hide</td></tr><tr><td><dialog></td><td>Defines a dialog box or window</td></tr><tr><td><figcaption></td><td>Defines a caption for a <figure> element</td></tr><tr><td><figure></td><td>Defines self-contained content, like illustrations, diagrams, photos, code listings, etc.</td></tr><tr><td><footer></td><td>Defines a footer for the document or a section</td></tr><tr><td><header></td><td>Defines a header for the document or a section</td></tr><tr><td><main></td><td>Defines the main content of a document</td></tr><tr><td><mark></td><td>Defines marked or highlighted text</td></tr><tr><td><menuitem></td><td>Defines a command/menu item that the user can invoke from a popup menu</td></tr><tr><td><meter></td><td>Defines a scalar measurement within a known range (a gauge)</td></tr><tr><td><nav></td><td>Defines navigation links in the document</td></tr><tr><td><progress></td><td>Defines the progress of a task</td></tr><tr><td><rp></td><td>Defines what to show in browsers that do not support ruby annotations</td></tr><tr><td><rt></td><td>Defines an explanation/pronunciation of characters (for East Asian typography)</td></tr><tr><td><ruby></td><td>Defines a ruby annotation (for East Asian typography)</td></tr><tr><td><section></td><td>Defines a section in the document</td></tr><tr><td><summary></td><td>Defines a visible heading for a <details> element</td></tr><tr><td><time></td><td>Defines a date/time</td></tr><tr><td><wbr></td><td>Defines a possible line-break</td></tr></tbody></table><p>These semantic tags offer greater context to the elements which are contained within them.</p><h4>Form Tags</h4><p>The new spec also defines form elements that give greater context to fields and content within forms.</p><table align='center' cellspacing='1'><thead><tr><th scope='col'>Tag</th><th scope='col'>Description</th></tr></thead><tbody><tr><td><datalist></td><td>Defines pre-defined options for input controls</td></tr><tr><td><keygen></td><td>Defines a key-pair generator field (for forms)</td></tr><tr><td><output></td><td>Defines the result of a calculation</td></tr></tbody></table><p>These new form tags can be used as a basis for richer data gathering through HTML forms.</p><h4>Graphics Tags</h4><p>As the web advances with more powerful browsers, rich graphics have become a core part of every web experience. HTML5 defines new graphic elements.</p><table align='center' cellspacing='1'><thead><tr><th scope='col'>Tag</th><th scope='col'>Description</th></tr></thead><tbody><tr><td><canvas></td><td>Defines graphic drawing using JavaScript</td></tr><tr><td><svg></td><td>Defines graphic drawing using SVG</td></tr></tbody></table><p>These new graphics tags really shine when used with JavaScript libraries that boost their interactivity.</p><h4>Media Tags</h4><p>Greater connection speeds have rolled out around the world since the last major HTML specification was created. Broadband is standard in much of the developed world with mobile devices having incredible connection speeds compared to the days of the 56k dial-up modem. We now have media as part of nearly every webpage: video, audio, and images. The new spec gives media a set of tags and attributes appropriate to them.</p><table align='center' cellspacing='1'><thead><tr><th scope='col'>Tag</th><th scope='col'>Description</th></tr></thead><tbody><tr><td><audio></td><td>Defines sound or music content</td></tr><tr><td><embed></td><td>Defines containers for external applications (like plug-ins)</td></tr><tr><td><source></td><td>Defines sources for <video> and <audio></td></tr><tr><td><track></td><td>Defines tracks for <video> and <audio></td></tr><tr><td><video></td><td>Defines video or movie content</td></tr></tbody></table><p>The HTML5 video tag is one of the most interesting HTML5 features. Video is a major part of the modern web but it's been implemented through the Adobe Flash plugin for years. Flash is generally not supported on mobile devices and can be a bit of an energy/performance hog. The HTML5 video tag, and related JavaScript libraries, promise to provide support for streaming video in native HTML.</p><h3>HTML5 Input Types</h3><p>HTML5 extends the <input> tag's <em>type </em>attribute to support man new forms of data gathering. New type options include:</p><ul><li>search</li><li>email</li><li>url</li><li>tel</li><li>number</li><li>range</li><li>date</li><li>month</li><li>week</li><li>time</li><li>datetime</li><li>datetime-local</li><li>color</li></ul><h3 id='drupal-theming-course'>Drupal Theming Course</h3><p>These new type options are handled in different ways across browsers.</p><h3>What is Relevant in HTML5?</h3><p>There's many other technologies that get conflated with HTML5 like CSS3, Websockets, or the Flash Killer: Canvas. CSS3 is a new specification for cascading style sheets, which does often go hand-in-hand with HTML5, but isn't actually under it. Websockets is an API that creates a bi-directional mode of communication over a single TCP connection (think of push/pull). As amazing as Canvas is, without a supporting JavaScript library, it's nothing more than another semantic tag further defining our old divs. If you'd like to check if a particular HTML5 tag or attribute is supported by a particular browser version, this tool will verify compatibility.</p><h4>Semantic HTML: Further Context and Purpose to Your Content</h4><p>What HTML5 offers as the core part of the spec is further context to your content. No longer does all content live inside <em>div</em> tags. Instead, the containing elements offer an extra layer of context to the content which resides within them. An <em>article </em>is intended to define your page's core information, content which could live by itself. This is the meat of any page. An <em>aside</em> is tangentially related information (perhaps even 'related content'), links, and data. It's relevant to the <em>article</em> but not data which makes much sense by itself. <em>Nav</em> elements contain the menu or navigation system for your website.</p><h2>Integrating Drupal HTML5 in Drupal 7</h2><p>The primary way you'll upgrade your Drupal 7 website to HTML5 is actually through your theme. You won't need to rewrite <em>everything</em> if you can utilize an HTML5-based Drupal 7 theme. If you happened to use a base theme which has now migrated from XHTML to HTML5, the theme developer should provide an upgrade path. If you happen to be working with an older theme that hasn't upgraded to HTML5 or you have a custom theme, you may need to rewrite some of your template files to match the new spec. Nathan Smith offers an excellent guide to getting started rewriting these template/.tpl files. Themes generally override the core template files that Drupal provides. These template files contain the actual HTML which is output by the CMS. </p><h3>Drupal Modules for Drupal HTML5 Support and Integration</h3><p>There's several Drupal modules that focus on providing compatibility and integration with HTML5 elements within Drupal's existing systems.</p><ul><li>Elements - provides support for advanced form elements which are the core of Drupal fields</li><li>Video - handles various video file trouble with HTML5 video elements; codecs, streaming, thumbnails</li><li>Geolocation - gather the user's location or store latitude and longitude coordinates</li><li>HTML5 Tools - connects the Elements (above) fields to Drupal systems and primary modules like Views</li></ul><p>The HTML5 Tools module for Drupal 7 helps make the new HTML5 input types standard and provides methods to utilize them within the CMS. These input types are mentioned above.</p><h3>HTML5 JavaScript Compatibility Tools</h3><p>Aside from adjusting tags to appropriately match the HTML5 spec, most HTML5 Drupal Themes will utilize JavaScript libraries to solve compatibility problems in older browsers that do not support the spec. The most important HTML5 JavaScript compatibility plugins are:</p><ul><li>Modernizer - detects browser capability, provides capability indications within the DOM</li><li>HTML5 Shiv - provides support for HTML5 elements in older Internet Explorer browsers</li></ul><h3>Drupal 7 Themes built on HTML5</h3><p>The best HTML5-based Drupal 7 themes we've found through several project builds are:</p><ul><li>Base or Starter Themes:<ul><li>Omega - developer focused, JavaScript compatibility libraries, page layout system</li><li>Zen - hugely popular, tons of choice and control from the admin interface</li><li>Adaptive - point-and-click interface for controlling device size media queries</li><li>Fusion - integrates well with grid/layout systems</li></ul></li><li>Functional Themes:<ul><li>Corporate Clean - popular starter design for professional sites</li><li>Business - clean grid starting design for business sites</li></ul></li></ul><p>Some of these Drupal Themes are compatible with version 6 or 8. If you're looking for HTML5-focussed themes for Drupal 6 or Drupal 8, these themes are also a great place to start.</p><p>Curious about what we use on a majority of our projects? It's Omega, a lovely base theme targeted to dev/designers ready to code. Out of the box, Omega reminds me of the clean slate offered by the HTML5 Boilerplate framework (<em>sidenote</em>: there is a Drupal theme based on this HTML framework, but it gets little activity or support). There's very little markup to fight from the start, and Omega does a great job of stripping unnecessary classes and markup as much as is possible within Drupal. Omega uses a flexible layout system (sort of like a sub-subtheme), and a mobile first design system. We love Omega.</p><h3>Does my Drupal HTML5 Website Validate?</h3><p>W3C offers an excellent validation tool that's been updated as the HTML5 spec is updated. You'll always be validating against the latest agreed requirements as long as you're using the W3C HTML Validator. The validation tool will give you errors and warnings that pertain to particular tags, syntax, or attributes. The tool also offers suggestions and direction to solve the problem area. Once you're ready to begin testing, plugin your URL to the W3C HTML Validator and be sure the doctype is detected automatically as HTML5. If you're having trouble configuring your Drupal site to match the HTML5 standard or want to integrate new technologies provided by the spec, we offer focussed Drupal implementation services.</p><h3 id='drupal-8-theming-with-twig'>Drupal 8 Theming With Twig</h3><h2>The Future of Drupal HTML5 and Drupal 8</h2><p>Drupal 7 wasn't built from scratch to support HTML5. However, Drupal 8 will ship with integrated support for HTML5, and at the time of writing Drupal 8 is in beta. The future is looking bright for Drupal and HTML5.</p><h3 id='drupal-theming-tutorial'>Drupal Theming Tutorial</h3><p>The reason you should care about HTML5 is that it leads the web towards a more defined standard for its information. This makes it easier for search engines, algorithms, APIs; any computer reading your content to better understand what it's about and the purpose. This makes for easier curation and stronger relevance. Delivering relevant information for what a user is seeking is a core part of the web as we know it, HTML5 is a step towards making that experience even better.</p><p>If you like this Drupal guide to HTML5, consider sharing it. Do you have suggestions for Drupal HTML5 integration? Corrections? Questions? Connect with us!</p><br><br><br><br>
broken image