<html>
<head>
<title>Książka z serwisu WolneLektury.pl</title>
- <meta http-equiv="content-type" content="text/html;charset=utf-8"/>
- </head>
- <style>
- body {
- font-size: 16px;
- font: Georgia, "Times New Roman", serif;
- line-height: 1.5em;
- margin: 0;
- }
-
- a {
- color: blue;
- text-decoration: none;
- }
-
- #book-text {
- margin: 3em;
- max-width: 36em;
- }
-
- /* ================================== */
- /* = Header with logo and menu = */
- /* ================================== */
- #header {
- margin: 3.4em 0 0 1.4em;
- }
-
- img {
- border: none;
- }
-
-
- #menu {
- position: fixed;
- left: 0em;
- top: 0em;
- width: 100%;
- height: 1.5em;
- background: #333;
- color: #FFF;
- opacity: 0.9;
- z-index: 99;
- }
-
- #menu ul {
- list-style: none;
- padding: 0;
- margin: 0;
- }
-
- #menu li a {
- display: block;
- float: left;
- width: 7.5em;
- height: 1.5em;
- margin-left: 0.5em;
- text-align: center;
- color: #FFF;
- }
-
- #menu li a:hover, #menu li a:active {
- color: #000;
- background: #FFF url(/static/img/arrow-down.png) no-repeat center right;
- }
-
- #menu li a.selected {
- color: #000;
- background: #FFF url(/static/img/arrow-up.png) no-repeat center right;
- }
- #menu a.menu-link {
- display: block;
- float: left;
- height: 1.5em;
- margin-left: 0.5em;
- text-align: center;
- color: #FFF;
- }
- #menu span {
- color: #888;
- font-style: italic;
- font-size: .75em;
- margin-right: 0.5em;
- }
-
-
- #toc, #themes, #nota_red, #info {
- position: fixed;
- left: 0em;
- top: 1.5em;
- width: 37em;
- padding: 1.5em;
- background: #FFF;
- border-bottom: 0.25em solid #DDD;
- border-right: 0.25em solid #DDD;
- display: none;
- height: 16em;
- overflow-x: hidden;
- overflow-y: auto;
- opacity: 0.9;
- z-index: 99;
- }
-
- #toc ol, #themes ol {
- list-style: none;
- padding: 0;
- margin: 0;
- }
-
- #toc ol li {
- font-weight: bold;
- }
-
- #toc ol ol {
- padding: 0 0 1.5em 1.5em;
- margin: 0;
- }
-
- #toc ol ol li {
- font-weight: normal;
- }
-
- #toc h2 {
- display: none;
- }
-
- #toc .anchor {
- float: none;
- margin: 0;
- color: blue;
- font-size: 16px;
- position: inherit;
- }
-
- #info p {
- text-align: justify;
- margin: 1.5em 0 0;
- }
-
- /* =================================================== */
- /* = Common elements: headings, paragraphs and lines = */
- /* =================================================== */
- h1 {
- font-size: 3em;
- margin: 1.5em 0;
- text-align: center;
- line-height: 1.5em;
- font-weight: bold;
- }
-
- h2 {
- font-size: 2em;
- margin: 1.5em 0 0;
- font-weight: bold;
- line-height: 1.5em;
- }
-
- h3 {
- font-size: 1.5em;
- margin: 1.5em 0 0;
- font-weight: normal;
- line-height: 1.5em;
- }
-
- h4 {
- font-size: 1em;
- margin: 1.5em 0 0;
- line-height: 1.5em;
- }
-
- p {
- margin: 0;
- }
-
- /* ======================== */
- /* = Footnotes and themes = */
- /* ======================== */
- .theme-begin {
- border-left: 0.1em solid #DDDDDD;
- color: #777;
- padding: 0 0.5em;
- width: 7.5em;
-
- font-style: normal;
- font-weight: normal;
- font-variant: normal;
- letter-spacing: 0;
- text-transform: none;
- text-decoration: none;
-
- font-size: 16px;
- float: right;
- margin-right: -9.5em;
- margin-bottom: 0.5em;
- clear: both;
- left: 40em;
- line-height: 1.5em;
- text-align: left;
- }
-
- .annotation {
- font-style: normal;
- font-weight: normal;
- font-size: 12px;
- padding-left: 2px;
- position: relative;
- top: -4px;
- }
-
- #footnotes .annotation {
- display: block;
- float: left;
- width: 2.5em;
- clear: both;
- }
-
- #footnotes div {
- margin: 1.5em 0 0 0;
- }
-
- #footnotes p {
- margin-left: 2.5em;
- font-size: 0.875em;
- }
-
- blockquote {
- font-size: 0.875em;
- }
-
- /* ============= */
- /* = Numbering = */
- /* ============= */
- .verse, .paragraph {
- position:relative;
- }
- .anchor {
- position: absolute;
- margin: -0.25em -0.5em;
- left: -3em;
- color: #777;
- font-size: 12px;
- width: 2em;
- text-align: center;
- padding: 0.25em 0.5em;
- line-height: 1.5em;
- }
-
- .anchor:hover, #book-text .anchor:active {
- color: #FFF;
- background-color: #CCC;
- }
-
- /* =================== */
- /* = Custom elements = */
- /* =================== */
- span.author {
- font-size: 0.5em;
- display: block;
- line-height: 1.5em;
- margin-bottom: 0.25em;
- }
-
- span.collection {
- font-size: 0.375em;
- display: block;
- line-height: 1.5em;
- margin-bottom: -0.25em;
- }
-
- span.subtitle {
- font-size: 0.5em;
- display: block;
- line-height: 1.5em;
- margin-top: -0.25em;
- }
-
- span.translator {
- font-size: 0.375em;
- display: block;
- line-height: 1.5em;
- margin-top: 0.25em;
- }
-
- div.didaskalia {
- font-style: italic;
- margin: 0.5em 0 0 1.5em;
- }
-
- div.kwestia {
- margin: 0.5em 0 0;
- }
-
- div.stanza {
- margin: 1.5em 0 0;
- }
-
- div.kwestia div.stanza {
- margin: 0;
- }
-
- p.paragraph {
- text-align: justify;
- margin: 1.5em 0 0;
- }
-
- p.motto {
- text-align: justify;
- font-style: italic;
- margin: 1.5em 0 0;
- }
-
- p.motto_podpis {
- font-size: 0.875em;
- text-align: right;
- }
-
- div.fragment {
- border-bottom: 0.1em solid #999;
- padding-bottom: 1.5em;
- }
-
- div.note p, div.dedication p, div.note p.paragraph, div.dedication p.paragraph {
- text-align: right;
- font-style: italic;
- }
-
- hr.spacer {
- height: 3em;
- visibility: hidden;
- }
-
- hr.spacer-line {
- margin: 1.5em 0;
- border: none;
- border-bottom: 0.1em solid #000;
- }
-
- p.spacer-asterisk {
- padding: 0;
- margin: 1.5em 0;
- text-align: center;
- }
-
- div.person-list ol {
- list-style: none;
- padding: 0 0 0 1.5em;
- }
-
- p.place-and-time {
- font-style: italic;
- }
-
- em.math, em.foreign-word, em.book-title, em.didaskalia {
- font-style: italic;
- }
-
- em.author-emphasis {
- letter-spacing: 0.1em;
- }
-
- em.person {
- font-style: normal;
- font-variant: small-caps;
- }
-
- .verse:after {
- content: "\feff";
- }
-
-
- /* =================================== */
- /* = Hide some elements for printing = */
- /* =================================== */
-
- @media print {
- #menu {display: none;}
- }
- </style>
+ <meta charset="utf-8" />
+ <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1" />
+ <link href="https://static.wolnelektury.pl/css/compressed/book_text.css" rel="stylesheet" type="text/css" />
+ </head>
<body>
<xsl:call-template name="book-text" />
</body>
</xsl:template>
<xsl:template match="motto">
- <div class="motto"><xsl:apply-templates mode="inline" /></div>
+ <div class="motto"><xsl:apply-templates /></div>
</xsl:template>
<!-- Section headers (included in index)-->
<xsl:template match="naglowek_akt|naglowek_czesc|srodtytul">
+ <xsl:call-template name="section-anchor"/>
<h2><xsl:apply-templates mode="inline" /></h2>
</xsl:template>
<xsl:template match="naglowek_scena|naglowek_rozdzial">
+ <xsl:call-template name="section-anchor"/>
<h3><xsl:apply-templates mode="inline" /></h3>
</xsl:template>
<xsl:template match="naglowek_osoba|naglowek_podrozdzial">
+ <xsl:call-template name="section-anchor"/>
<h4><xsl:apply-templates mode="inline" /></h4>
</xsl:template>
<!-- Other paragraph tags -->
<xsl:template match="miejsce_czas">
+ <xsl:call-template name="section-anchor"/>
<p class="place-and-time"><xsl:apply-templates mode="inline" /></p>
</xsl:template>
<xsl:template match="didaskalia">
+ <xsl:call-template name="section-anchor"/>
<div class="didaskalia"><xsl:apply-templates mode="inline" /></div>
</xsl:template>
<xsl:template match="akap|akap_dialog|akap_cd">
<p class="paragraph">
- <a name="{concat('sect', position())}" />
+ <xsl:call-template name="section-anchor"/>
<xsl:apply-templates mode="inline" />
</p>
</xsl:template>
<xsl:template match="strofa">
<div class="stanza">
- <a name="{concat('sect', position())}" />
+ <xsl:call-template name="section-anchor"/>
<xsl:choose>
<xsl:when test="count(br) > 0">
<xsl:call-template name="verse">
<xsl:value-of select="wl:substitute_entities(.)" />
</xsl:template>
+<!-- ========= -->
+<!-- = utils = -->
+<!-- ========= -->
+<xsl:template name="section-anchor">
+ <!--
+ this formula works as follows:
+ - get all ancestors including self
+ - choose the header (third one from root): utwor/book-type/header
+ - get all preceding siblings
+ - count them
+ - create an <a name="sec123"/> tag.
+ -->
+ <a name="{concat('sec', count(ancestor-or-self::*[last()-2]/preceding-sibling::*) + 1)}" />
+</xsl:template>
</xsl:stylesheet>