Created
November 5, 2022 12:40
-
-
Save robmarshall/caafd8a4328db0e58cf721a307af64e1 to your computer and use it in GitHub Desktop.
Sitemap Template for Next JS Article
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?xml version="1.0" encoding="UTF-8"?> | |
<xsl:stylesheet version="2.0" | |
xmlns:html="http://www.w3.org/TR/REC-html40" | |
xmlns:image="http://www.google.com/schemas/sitemap-image/1.1" | |
xmlns:sitemap="http://www.sitemaps.org/schemas/sitemap/0.9" | |
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> | |
<xsl:output method="html" version="1.0" encoding="UTF-8" indent="yes"/> | |
<xsl:template match="/"> | |
<html xmlns="http://www.w3.org/1999/xhtml"> | |
<head> | |
<title>XML Sitemap</title> | |
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> | |
<style type="text/css"> | |
body { | |
font-family: Helvetica, Arial, sans-serif; | |
font-size: 13px; | |
color: #545353; | |
} | |
table { | |
border: none; | |
border-collapse: collapse; | |
} | |
#sitemap tr:nth-child(odd) td { | |
background-color: #eee !important; | |
} | |
#sitemap tbody tr:hover td { | |
background-color: #ccc; | |
} | |
#sitemap tbody tr:hover td, #sitemap tbody tr:hover td a { | |
color: #000; | |
} | |
#content { | |
margin: 0 auto; | |
width: 1000px; | |
} | |
a { | |
color: #000; | |
text-decoration: none; | |
} | |
a:visited { | |
color: #777; | |
} | |
a:hover { | |
text-decoration: underline; | |
} | |
td { | |
font-size:11px; | |
} | |
th { | |
text-align:left; | |
padding-right:30px; | |
font-size:11px; | |
} | |
thead th { | |
border-bottom: 1px solid #000; | |
} | |
</style> | |
</head> | |
<body> | |
<div id="content"> | |
<h1>XML Sitemap</h1> | |
<xsl:if test="count(sitemap:sitemapindex/sitemap:sitemap) > 0"> | |
<table id="sitemap" cellpadding="3"> | |
<thead> | |
<tr> | |
<th width="75%">Sitemap</th> | |
<th width="25%">Last Modified</th> | |
</tr> | |
</thead> | |
<tbody> | |
<xsl:for-each select="sitemap:sitemapindex/sitemap:sitemap"> | |
<xsl:variable name="sitemapURL"> | |
<xsl:value-of select="sitemap:loc"/> | |
</xsl:variable> | |
<tr> | |
<td> | |
<a href="{$sitemapURL}"><xsl:value-of select="sitemap:loc"/></a> | |
</td> | |
<td> | |
<xsl:value-of select="concat(substring(sitemap:lastmod,0,11),concat(' ', substring(sitemap:lastmod,12,5)),concat(' ', substring(sitemap:lastmod,20,6)))"/> | |
</td> | |
</tr> | |
</xsl:for-each> | |
</tbody> | |
</table> | |
</xsl:if> | |
<xsl:if test="count(sitemap:sitemapindex/sitemap:sitemap) < 1"> | |
<table id="sitemap" cellpadding="3"> | |
<thead> | |
<tr> | |
<th width="80%">URL</th> | |
<th width="5%">Images</th> | |
<th title="Last Modification Time" width="15%">Last Mod.</th> | |
</tr> | |
</thead> | |
<tbody> | |
<xsl:variable name="lower" select="'abcdefghijklmnopqrstuvwxyz'"/> | |
<xsl:variable name="upper" select="'ABCDEFGHIJKLMNOPQRSTUVWXYZ'"/> | |
<xsl:for-each select="sitemap:urlset/sitemap:url"> | |
<tr> | |
<td> | |
<xsl:variable name="itemURL"> | |
<xsl:value-of select="sitemap:loc"/> | |
</xsl:variable> | |
<a href="{$itemURL}"> | |
<xsl:value-of select="sitemap:loc"/> | |
</a> | |
</td> | |
<td> | |
<xsl:value-of select="count(image:image)"/> | |
</td> | |
<td> | |
<xsl:value-of select="concat(substring(sitemap:lastmod,0,11),concat(' ', substring(sitemap:lastmod,12,5)),concat(' ', substring(sitemap:lastmod,20,6)))"/> | |
</td> | |
</tr> | |
</xsl:for-each> | |
</tbody> | |
</table> | |
</xsl:if> | |
</div> | |
</body> | |
</html> | |
</xsl:template> | |
</xsl:stylesheet> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment