90 lines
		
	
	
		
			77 KiB
		
	
	
	
		
			XML
		
	
	
	
	
	
		
		
			
		
	
	
			90 lines
		
	
	
		
			77 KiB
		
	
	
	
		
			XML
		
	
	
	
	
	
|   | <?xml version="1.0" encoding="utf-8"?> | |||
|  | <!--
 | |||
|  | 
 | |||
|  | # Pretty Atom Feed | |||
|  | 
 | |||
|  | Based on "Pretty RSS Feed": https://github.com/genmon/aboutfeeds/issues/26 | |||
|  | 
 | |||
|  | Styles an Atom feed, making it friendly for humans viewers, and adds a link | |||
|  | to aboutfeeds.com for new user onboarding. See it in action: | |||
|  | 
 | |||
|  | https://nicolas-hoizey.com/feeds/all.xml | |||
|  | 
 | |||
|  | --> | |||
|  | <xsl:stylesheet version="3.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" | |||
|  |                 xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/" | |||
|  |                 xmlns:itunes="http://www.itunes.com/dtds/podcast-1.0.dtd"> | |||
|  |   <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><xsl:value-of select="atom:feed/atom:title"/></title> | |||
|  |         <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> | |||
|  |         <meta name="viewport" content="width=device-width, initial-scale=1"/> | |||
|  |         <style type="text/css">/*! normalize.css v4.1.1 | MIT License | github.com/necolas/normalize.css */html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}article,aside,details,figcaption,figure,footer,header,main,menu,nav,section{display:block}summary{display:list-item}audio,canvas,progress,video{display:inline-block}audio:not([controls]){display:none;height:0}progress{vertical-align:baseline}[hidden],template{display:none!important}a{background-color:transparent}a:active,a:hover{outline-width:0}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:inherit}b,strong{font-weight:bolder}dfn{font-style:italic}h1{font-size:2em;margin:.67em 0}mark{background-color:#ff0;color:#000}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}svg:not(:root){overflow:hidden}code,kbd,pre,samp{font-family:monospace,monospace;font-size:1em}figure{margin:1em 40px}hr{box-sizing:content-box;height:0;overflow:visible}button,input,select,textarea{font:inherit;margin:0}optgroup{font-weight:700}button,input{overflow:visible}button,select{text-transform:none}[type=reset],[type=submit],button,html [type=button]{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-input-placeholder{color:inherit;opacity:.54}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}*{box-sizing:border-box}button,input,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit}body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol";font-size:14px;line-height:1.5;color:#24292e;background-color:#fff}a{color:#0366d6;text-decoration:none}a:hover{text-decoration:underline}b,strong{font-weight:600}.rule,hr{height:0;margin:15px 0;overflow:hidden;background:0 0;border:0;border-bottom:1px solid #dfe2e5}.rule::before,hr::before{display:table;content:""}.rule::after,hr::after{display:table;clear:both;content:""}table{border-spacing:0;border-collapse:collapse}td,th{padding:0}button{cursor:pointer;border-radius:0}[hidden][hidden]{display:none!important}details summary{cursor:pointer}details:not([open])>* :not(summary){display:none!important}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:0}h1{font-size:32px;font-weight:600}h2{font-size:24px;font-weight:600}h3{font-size:20px;font-weight:600}h4{font-size:16px;font-weight:600}h5{font-size:14px;font-weight:600}h6{font-size:12px;font-weight:600}p{margin-top:0;margin-bottom:10px}small{font-size:90%}blockquote{margin:0}ol,ul{padding-left:0;margin-top:0;margin-bottom:0}ol ol,ul ol{list-style-type:lower-roman}ol ol ol,ol ul ol,ul ol ol,ul ul ol{list-style-type:lower-alpha}dd{margin-left:0}code,tt{font-family:SFMono-Regular,Consolas,"Liberation Mono",Menlo,Courier,monospace;font-size:12px}pre{margin-top:0;margin-bottom:0;font-family:SFMono-Regular,Consolas,"Liberation Mono",Menlo,Courier,monospace;font-size:12px}.octicon{vertical-align:text-bottom}.anim-fade-in{animation-name:fade-in;animation-duration:1s;animation-timing-function:ease-in-out}.anim-fade-in.fast{animation-duration:.3s}@keyframes fade-in{0%{opacity:0}100%{opacity:1}}.anim-fade-out{animatio | |||
|  |       </head> | |||
|  |       <body class="bg-white"> | |||
|  |         <nav class="container-md px-3 py-2 mt-2 mt-md-5 mb-5 markdown-body"> | |||
|  |           <p class="bg-yellow-light ml-n1 px-1 py-1 mb-1"> | |||
|  |             <strong>This is a web feed,</strong> also known as an RSS or Atom feed. <strong>Subscribe</strong> by copying the URL from the address bar into your newsreader. | |||
|  |           </p> | |||
|  |           <p class="text-gray"> | |||
|  |             Visit <a href="https://aboutfeeds.com">About Feeds</a> to get started with newsreaders and subscribing. It’s free. | |||
|  |           </p> | |||
|  |         </nav> | |||
|  |         <div class="container-md px-3 py-3 markdown-body"> | |||
|  |           <header class="py-5"> | |||
|  |             <h1 class="border-0"> | |||
|  |               <!-- https://commons.wikimedia.org/wiki/File:Feed-icon.svg --> | |||
|  |               <svg xmlns="http://www.w3.org/2000/svg" version="1.1" style="vertical-align: text-bottom; width: 1.2em; height: 1.2em;" class="pr-1" id="RSSicon" viewBox="0 0 256 256"> | |||
|  |                 <defs> | |||
|  |                   <linearGradient x1="0.085" y1="0.085" x2="0.915" y2="0.915" id="RSSg"> | |||
|  |                     <stop  offset="0.0" stop-color="#E3702D"/><stop  offset="0.1071" stop-color="#EA7D31"/> | |||
|  |                     <stop  offset="0.3503" stop-color="#F69537"/><stop  offset="0.5" stop-color="#FB9E3A"/> | |||
|  |                     <stop  offset="0.7016" stop-color="#EA7C31"/><stop  offset="0.8866" stop-color="#DE642B"/> | |||
|  |                     <stop  offset="1.0" stop-color="#D95B29"/> | |||
|  |                   </linearGradient> | |||
|  |                 </defs> | |||
|  |                 <rect width="256" height="256" rx="55" ry="55" x="0"  y="0"  fill="#CC5D15"/> | |||
|  |                 <rect width="246" height="246" rx="50" ry="50" x="5"  y="5"  fill="#F49C52"/> | |||
|  |                 <rect width="236" height="236" rx="47" ry="47" x="10" y="10" fill="url(#RSSg)"/> | |||
|  |                 <circle cx="68" cy="189" r="24" fill="#FFF"/> | |||
|  |                 <path d="M160 213h-34a82 82 0 0 0 -82 -82v-34a116 116 0 0 1 116 116z" fill="#FFF"/> | |||
|  |                 <path d="M184 213A140 140 0 0 0 44 73 V 38a175 175 0 0 1 175 175z" fill="#FFF"/> | |||
|  |               </svg> | |||
|  | 
 | |||
|  |               Web Feed Preview | |||
|  |             </h1> | |||
|  |             <h2><xsl:value-of select="atom:feed/atom:title"/></h2> | |||
|  |             <p><xsl:value-of select="atom:feed/atom:description"/></p> | |||
|  |             <p>This preview only shows titles, but the actual feed contains the full content.</p> | |||
|  |             <a class="head_link"> | |||
|  |               <xsl:attribute name="href"> | |||
|  |                 <xsl:value-of select="/atom:feed/atom:link[not(@rel)]/@href"/> | |||
|  |               </xsl:attribute> | |||
|  |               Visit Website → | |||
|  |             </a> | |||
|  |           </header> | |||
|  |           <h2>Recent Items</h2> | |||
|  |           <xsl:apply-templates select="atom:feed/atom:entry" /> | |||
|  |         </div> | |||
|  |       </body> | |||
|  |     </html> | |||
|  |   </xsl:template> | |||
|  |   <xsl:template match="atom:feed/atom:entry"> | |||
|  |     <div class="pb-5"> | |||
|  |       <h3 class="mb-0"> | |||
|  |         <a> | |||
|  |           <xsl:attribute name="href"> | |||
|  |             <xsl:value-of select="atom:link/@href"/> | |||
|  |           </xsl:attribute> | |||
|  |           <xsl:value-of select="atom:title"/> | |||
|  |         </a> | |||
|  |       </h3> | |||
|  |       <small class="text-gray"> | |||
|  |         Published: <xsl:value-of select="atom:updated" /> | |||
|  |       </small> | |||
|  |     </div> | |||
|  |   </xsl:template> | |||
|  | </xsl:stylesheet> |