Mayx's Home Page https://mabbs.github.io
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

108 lines
5.2 KiB

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!--
  3. # Pretty Atom Feed
  4. Based on "Pretty RSS Feed": https://github.com/genmon/aboutfeeds/issues/26
  5. Styles an Atom feed, making it friendly for humans viewers, and adds a link
  6. to aboutfeeds.com for new user onboarding. See it in action:
  7. https://nicolas-hoizey.com/feeds/all.xml
  8. -->
  9. <xsl:stylesheet
  10. version="3.0"
  11. xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
  12. xmlns:atom="http://www.w3.org/2005/Atom">
  13. <xsl:output method="html" version="4.0" encoding="UTF-8" indent="yes"/>
  14. <xsl:template match="/">
  15. <html xmlns="http://www.w3.org/1999/xhtml" lang="en">
  16. <head>
  17. <meta charset="utf-8"/>
  18. <meta name="viewport" content="width=device-width, initial-scale=1"/>
  19. <title>
  20. Web Feed |
  21. <xsl:value-of select="/atom:feed/atom:title"/><xsl:value-of select="/rss/channel/title"/>
  22. </title>
  23. <style type="text/css">*{box-sizing:border-box}body{background-color:#fff;color:#24292e;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol";line-height:1.5}a{color:#0366d6;text-decoration:none}a:hover{text-decoration:underline}.container{max-width:40rem;margin:1rem auto;padding:1rem}nav{margin-top:2rem;margin-bottom:2rem}p{margin-top:0;margin-bottom:1rem}h1,h2,h3{margin-top:0;margin-bottom:1rem;font-weight:600;line-height:1.25}h1{padding-bottom:.3em;font-size:2em}h1 svg{padding-right:.25rem;vertical-align:text-bottom;width:1.2em;height:1.2em}h2{margin-top:1.5rem;padding-bottom:.3em;font-size:1.5em;border-bottom:1px solid #eaecef}h3{font-size:1.25em;margin-bottom:0}.about{background-color:#fff5b1;margin:.25rem -.25rem;padding:.25rem}header{padding-top:2rem;padding-bottom:2rem}.item{padding-bottom:2rem}.gray{color:#586069}</style>
  24. </head>
  25. <body>
  26. <nav class="container">
  27. <p class="about">
  28. <strong>This is a web feed,</strong> also known as an RSS or Atom feed.<br /><strong>Subscribe</strong> by copying the URL from the address bar into your newsreader.
  29. </p>
  30. <p class="gray">
  31. Visit <a href="https://aboutfeeds.com">About Feeds</a> to get started with newsreaders and subscribing. It’s free.
  32. </p>
  33. </nav>
  34. <div class="container">
  35. <header>
  36. <h1>
  37. <svg xmlns="http://www.w3.org/2000/svg" version="1.1" viewBox="0 0 256 256">
  38. <defs>
  39. <linearGradient x1="0.085" y1="0.085" x2="0.915" y2="0.915" id="RSSg">
  40. <stop offset="0.0" stop-color="#E3702D"/><stop offset="0.1071" stop-color="#EA7D31"/>
  41. <stop offset="0.3503" stop-color="#F69537"/><stop offset="0.5" stop-color="#FB9E3A"/>
  42. <stop offset="0.7016" stop-color="#EA7C31"/><stop offset="0.8866" stop-color="#DE642B"/>
  43. <stop offset="1.0" stop-color="#D95B29"/>
  44. </linearGradient>
  45. </defs>
  46. <rect width="256" height="256" rx="55" ry="55" x="0" y="0" fill="#CC5D15"/>
  47. <rect width="246" height="246" rx="50" ry="50" x="5" y="5" fill="#F49C52"/>
  48. <rect width="236" height="236" rx="47" ry="47" x="10" y="10" fill="url(#RSSg)"/>
  49. <circle cx="68" cy="189" r="24" fill="#FFF"/>
  50. <path d="M160 213h-34a82 82 0 0 0 -82 -82v-34a116 116 0 0 1 116 116z" fill="#FFF"/>
  51. <path d="M184 213A140 140 0 0 0 44 73 V 38a175 175 0 0 1 175 175z" fill="#FFF"/>
  52. </svg>
  53. Web Feed Preview
  54. </h1>
  55. <h2><xsl:value-of select="atom:feed/atom:title"/><xsl:value-of select="/rss/channel/title"/></h2>
  56. <p><xsl:value-of select="atom:feed/atom:subtitle"/><xsl:value-of select="/rss/channel/description"/></p>
  57. <p>This preview only shows titles and summaries<xsl:if test="atom:feed">, but the actual feed contains the full content</xsl:if>.</p>
  58. <a href="/">
  59. Visit Website &#x2192;
  60. </a>
  61. </header>
  62. <h2>Recent Items</h2>
  63. <xsl:apply-templates select="atom:feed/atom:entry" />
  64. <xsl:apply-templates select="/rss/channel/item" />
  65. <footer>
  66. <small><p>Made with ❤ by Mayx</p></small>
  67. </footer>
  68. </div>
  69. </body>
  70. </html>
  71. </xsl:template>
  72. <xsl:template match="atom:feed/atom:entry">
  73. <div class="item">
  74. <h3>
  75. <a>
  76. <xsl:attribute name="href">
  77. <xsl:value-of select="atom:link/@href"/>
  78. </xsl:attribute>
  79. <xsl:value-of select="atom:title"/>
  80. </a>
  81. </h3>
  82. <small class="gray">
  83. Published at <xsl:value-of select="substring(atom:published, 0, 11)" />
  84. </small>
  85. <p><xsl:value-of select="atom:summary"/></p>
  86. </div>
  87. </xsl:template>
  88. <xsl:template match="/rss/channel/item">
  89. <div class="item">
  90. <h3>
  91. <a>
  92. <xsl:attribute name="href">
  93. <xsl:value-of select="link"/>
  94. </xsl:attribute>
  95. <xsl:value-of select="title"/>
  96. </a>
  97. </h3>
  98. <small class="gray">
  99. Published: <xsl:value-of select="substring(pubDate, 0, 17)" />
  100. </small>
  101. <p><xsl:value-of select="description"/></p>
  102. </div>
  103. </xsl:template>
  104. </xsl:stylesheet>

Powered by TurnKey Linux.