2019-10-21 04:22:28 -04:00
---
title: Internal Templates
description: Hugo ships with a group of boilerplate templates that cover the most common use cases for static websites.
categories: [templates]
keywords: [internal, analytics,]
menu:
docs:
2023-05-22 10:43:12 -04:00
parent: templates
2019-10-21 04:22:28 -04:00
weight: 168
weight: 168
toc: true
---
<!-- reference: https://discourse.gohugo.io/t/lookup - order - for - partials/5705/6
code: https://github.com/gohugoio/hugo/blob/e445c35d6a0c7f5fc2f90f31226cd1d46e048bbc/tpl/template_embedded.go#L147 -->
2023-05-22 10:43:12 -04:00
{{% note %}}
2019-10-21 04:22:28 -04:00
While the following internal templates are called similar to partials, they do *not* observe the partial template lookup order.
2023-05-22 10:43:12 -04:00
{{% /note %}}
2019-10-21 04:22:28 -04:00
## Google Analytics
2022-11-17 10:14:29 -05:00
Hugo ships with internal templates supporting Google Analytics, both [Google Analytics 4][GA4] (GA4) and Universal Analytics.
2022-12-20 05:04:41 -05:00
**Note:** Universal Analytics are deprecated. For details, see [Universal Analytics will be going away].
2022-11-17 10:14:29 -05:00
[GA4]: https://support.google.com/analytics/answer/10089681
[Universal Analytics will be going away]: https://support.google.com/analytics/answer/11583528
2019-10-21 04:22:28 -04:00
### Configure Google Analytics
2022-11-17 10:14:29 -05:00
Provide your tracking ID in your configuration file:
2019-10-21 04:22:28 -04:00
2022-11-17 10:14:29 -05:00
**Google Analytics 4 (gtag.js)**
2023-05-27 10:59:59 -04:00
{{< code-toggle file = "hugo" > }}
2022-11-17 10:14:29 -05:00
googleAnalytics = "G-MEASUREMENT_ID"
2021-04-20 14:21:45 -04:00
{{< / code-toggle > }}
2022-11-17 10:14:29 -05:00
**Google Universal Analytics (analytics.js)**
2023-05-27 10:59:59 -04:00
{{< code-toggle file = "hugo" > }}
2022-11-17 10:14:29 -05:00
googleAnalytics = "UA-PROPERTY_ID"
2019-10-21 04:22:28 -04:00
{{< / code-toggle > }}
### Use the Google Analytics Template
You can then include the Google Analytics internal template:
2022-11-17 10:14:29 -05:00
```go-html-template
{{ template "_internal/google_analytics_async.html" . }}
2019-10-21 04:22:28 -04:00
```
2022-11-17 10:14:29 -05:00
**Note:** The async template is _not_ suitable for Google Analytics 4.
2019-10-21 04:22:28 -04:00
2022-11-17 10:14:29 -05:00
```go-html-template
{{ template "_internal/google_analytics.html" . }}
2019-10-21 04:22:28 -04:00
```
2021-04-20 14:21:45 -04:00
2022-11-17 10:14:29 -05:00
If you want to create your own template, you can access the configured ID with `{{ site.Config.Services.GoogleAnalytics.ID }}` .
2019-10-21 04:22:28 -04:00
## Disqus
Hugo also ships with an internal template for [Disqus comments][disqus], a popular commenting system for both static and dynamic websites. In order to effectively use Disqus, you will need to secure a Disqus "shortname" by [signing up for the free service][disqussignup].
### Configure Disqus
2021-04-20 14:21:45 -04:00
To use Hugo's Disqus template, you first need to set a single configuration value:
2019-10-21 04:22:28 -04:00
2023-05-27 10:59:59 -04:00
{{< code-toggle file = "hugo" > }}
2021-12-08 02:42:31 -05:00
disqusShortname = "your-disqus-shortname"
2019-10-21 04:22:28 -04:00
{{< / code-toggle > }}
You also have the option to set the following in the front matter for a given piece of content:
* `disqus_identifier`
* `disqus_title`
* `disqus_url`
### Use the Disqus Template
To add Disqus, include the following line in templates where you want your comments to appear:
2022-11-17 10:14:29 -05:00
```go-html-template
2019-10-21 04:22:28 -04:00
{{ template "_internal/disqus.html" . }}
```
A `.Site.DisqusShortname` variable is also exposed from the config.
### Conditional Loading of Disqus Comments
Users have noticed that enabling Disqus comments when running the Hugo web server on `localhost` (i.e. via `hugo server` ) causes the creation of unwanted discussions on the associated Disqus account.
You can create the following `layouts/partials/disqus.html` :
2023-05-22 10:43:12 -04:00
{{< code file = "layouts/partials/disqus.html" > }}
2019-10-21 04:22:28 -04:00
< div id = "disqus_thread" > < / div >
< script type = "text/javascript" >
(function() {
// Don't ever inject Disqus on localhost--it creates unwanted
// discussions from 'localhost:1313' on your Disqus account...
if (window.location.hostname == "localhost")
return;
var dsq = document.createElement('script'); dsq.type = 'text/javascript'; dsq.async = true;
var disqus_shortname = '{{ .Site.DisqusShortname }}';
dsq.src = '//' + disqus_shortname + '.disqus.com/embed.js';
(document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(dsq);
})();
< / script >
< noscript > Please enable JavaScript to view the < a href = "https://disqus.com/?ref_noscript" > comments powered by Disqus.< / a > < / noscript >
< a href = "https://disqus.com/" class = "dsq-brlink" > comments powered by < span class = "logo-disqus" > Disqus< / span > < / a >
{{< / code > }}
The `if` statement skips the initialization of the Disqus comment injection when you are running on `localhost` .
You can then render your custom Disqus partial template as follows:
2022-11-17 10:14:29 -05:00
```go-html-template
2019-10-21 04:22:28 -04:00
{{ partial "disqus.html" . }}
```
## Open Graph
2022-11-17 10:14:29 -05:00
2019-10-21 04:22:28 -04:00
An internal template for the [Open Graph protocol ](https://ogp.me/ ), metadata that enables a page to become a rich object in a social graph.
This format is used for Facebook and some other sites.
### Configure Open Graph
Hugo's Open Graph template is configured using a mix of configuration variables and [front-matter ](/content-management/front-matter/ ) on individual pages.
2023-05-27 10:59:59 -04:00
{{< code-toggle file = "hugo" > }}
2019-10-21 04:22:28 -04:00
[params]
title = "My cool site"
images = ["site-feature-image.jpg"]
description = "Text about my cool site"
[taxonomies]
series = "series"
{{< / code-toggle > }}
{{< code-toggle file = "content/blog/my-post" > }}
title = "Post title"
description = "Text about this post"
date = "2006-01-02"
images = ["post-cover.png"]
audio = []
videos = []
series = []
tags = []
{{< / code-toggle > }}
Hugo uses the page title and description for the title and description metadata.
The first 6 URLs from the `images` array are used for image metadata.
2021-04-20 14:21:45 -04:00
If [page bundles ](/content-management/page-bundles/ ) are used and the `images` array is empty or undefined, images with filenames matching `*feature*` or `*cover*,*thumbnail*` are used for image metadata.
2019-10-21 04:22:28 -04:00
Various optional metadata can also be set:
- Date, published date, and last modified data are used to set the published time metadata if specified.
- `audio` and `videos` are URL arrays like `images` for the audio and video metadata tags, respectively.
- The first 6 `tags` on the page are used for the tags metadata.
- The `series` taxonomy is used to specify related "see also" pages by placing them in the same series.
2020-08-14 12:31:01 -04:00
If using YouTube this will produce a og:video tag like `<meta property="og:video" content="url">` . Use the `https://youtu.be/<id>` format with YouTube videos (example: `https://youtu.be/qtIqKaDlqXo` ).
2019-10-21 04:22:28 -04:00
### Use the Open Graph Template
To add Open Graph metadata, include the following line between the `<head>` tags in your templates:
2022-11-17 10:14:29 -05:00
```go-html-template
2019-10-21 04:22:28 -04:00
{{ template "_internal/opengraph.html" . }}
```
## Twitter Cards
An internal template for [Twitter Cards ](https://developer.twitter.com/en/docs/tweets/optimize-with-cards/overview/abouts-cards ),
metadata used to attach rich media to Tweets linking to your site.
### Configure Twitter Cards
Hugo's Twitter Card template is configured using a mix of configuration variables and [front-matter ](/content-management/front-matter/ ) on individual pages.
2023-05-27 10:59:59 -04:00
{{< code-toggle file = "hugo" > }}
2019-10-21 04:22:28 -04:00
[params]
images = ["site-feature-image.jpg"]
description = "Text about my cool site"
{{< / code-toggle > }}
{{< code-toggle file = "content/blog/my-post" > }}
title = "Post title"
description = "Text about this post"
images = ["post-cover.png"]
{{< / code-toggle > }}
If `images` aren't specified in the page front-matter, then hugo searches for [image page resources ](/content-management/image-processing/ ) with `feature` , `cover` , or `thumbnail` in their name.
2020-03-09 15:19:32 -04:00
If no image resources with those names are found, the images defined in the [site config ](/getting-started/configuration/ ) are used instead.
2019-10-21 04:22:28 -04:00
If no images are found at all, then an image-less Twitter `summary` card is used instead of `summary_large_image` .
Hugo uses the page title and description for the card's title and description fields. The page summary is used if no description is given.
2022-11-17 10:14:29 -05:00
The `.Site.Social.twitter` variable is exposed from the config as the value for `twitter:site` .
2019-10-21 04:22:28 -04:00
2023-05-27 10:59:59 -04:00
{{< code-toggle file = "hugo" > }}
2022-11-17 10:14:29 -05:00
[social]
twitter = "GoHugoIO"
{{< / code-toggle > }}
2019-10-21 04:22:28 -04:00
2022-11-17 10:14:29 -05:00
NOTE: The `@` will be added for you
```html
< meta name = "twitter:site" content = "@GoHugoIO" / >
2019-10-21 04:22:28 -04:00
```
2022-11-17 10:14:29 -05:00
### Use the Twitter Cards Template
To add Twitter card metadata, include the following line immediately after the `<head>` element in your templates:
```go-html-template
2019-10-21 04:22:28 -04:00
{{ template "_internal/twitter_cards.html" . }}
```
## The Internal Templates
2022-11-17 10:14:29 -05:00
The code for these templates is located [here ](https://github.com/gohugoio/hugo/tree/master/tpl/tplimpl/embedded/templates ).
2019-10-21 04:22:28 -04:00
* `_internal/disqus.html`
* `_internal/google_analytics.html`
* `_internal/google_analytics_async.html`
* `_internal/opengraph.html`
* `_internal/pagination.html`
* `_internal/schema.html`
* `_internal/twitter_cards.html`
[disqus]: https://disqus.com
[disqussignup]: https://disqus.com/profile/signup/