xref: /webtrees/app/Report/ReportHtmlFootnote.php (revision dd04c183d8beed05be2226b30b7dda485ea4538a)
1a25f0a04SGreg Roach<?php
2*dd04c183SGreg Roachnamespace Fisharebest\Webtrees;
3a25f0a04SGreg Roach
4a25f0a04SGreg Roach/**
5a25f0a04SGreg Roach * webtrees: online genealogy
6a25f0a04SGreg Roach * Copyright (C) 2015 webtrees development team
7a25f0a04SGreg Roach * This program is free software: you can redistribute it and/or modify
8a25f0a04SGreg Roach * it under the terms of the GNU General Public License as published by
9a25f0a04SGreg Roach * the Free Software Foundation, either version 3 of the License, or
10a25f0a04SGreg Roach * (at your option) any later version.
11a25f0a04SGreg Roach * This program is distributed in the hope that it will be useful,
12a25f0a04SGreg Roach * but WITHOUT ANY WARRANTY; without even the implied warranty of
13a25f0a04SGreg Roach * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14a25f0a04SGreg Roach * GNU General Public License for more details.
15a25f0a04SGreg Roach * You should have received a copy of the GNU General Public License
16a25f0a04SGreg Roach * along with this program. If not, see <http://www.gnu.org/licenses/>.
17a25f0a04SGreg Roach */
18a25f0a04SGreg Roach
19a25f0a04SGreg Roach/**
20a25f0a04SGreg Roach * class ReportHtmlFootnote
21a25f0a04SGreg Roach */
22a25f0a04SGreg Roachclass ReportHtmlFootnote extends ReportBaseFootnote {
23a25f0a04SGreg Roach	/**
24a25f0a04SGreg Roach	 * HTML Footnotes number renderer
25a25f0a04SGreg Roach	 *
26a25f0a04SGreg Roach	 * @param ReportHtml $renderer
27a25f0a04SGreg Roach	 *
28a25f0a04SGreg Roach	 * @return void
29a25f0a04SGreg Roach	 */
30a25f0a04SGreg Roach	function render($renderer) {
31a25f0a04SGreg Roach		$renderer->setCurrentStyle("footnotenum");
32a25f0a04SGreg Roach		echo "<a href=\"#footnote", $this->num, "\"><sup>";
33a25f0a04SGreg Roach		$renderer->write($renderer->entityRTL . $this->num);
34a25f0a04SGreg Roach		echo "</sup></a>\n";
35a25f0a04SGreg Roach	}
36a25f0a04SGreg Roach
37a25f0a04SGreg Roach	/**
38a25f0a04SGreg Roach	 * Write the Footnote text
39a25f0a04SGreg Roach	 * Uses style name "footnote" by default
40a25f0a04SGreg Roach	 *
41a25f0a04SGreg Roach	 * @param ReportHtml $html
42a25f0a04SGreg Roach	 *
43a25f0a04SGreg Roach	 * @return void
44a25f0a04SGreg Roach	 */
45a25f0a04SGreg Roach	function renderFootnote($html) {
46a25f0a04SGreg Roach
47a25f0a04SGreg Roach		if ($html->getCurrentStyle() != $this->styleName) {
48a25f0a04SGreg Roach			$html->setCurrentStyle($this->styleName);
49a25f0a04SGreg Roach		}
50a25f0a04SGreg Roach
51a25f0a04SGreg Roach		$temptext = str_replace("#PAGENUM#", $html->pageNo(), $this->text);
52a25f0a04SGreg Roach		// underline «title» part of Source item
53a25f0a04SGreg Roach		$temptext = str_replace(array('«', '»'), array('<u>', '</u>'), $temptext);
54a25f0a04SGreg Roach		echo "\n<div><a name=\"footnote", $this->num, "\"></a>";
55a25f0a04SGreg Roach		$html->write($this->num . ". " . $temptext);
56a25f0a04SGreg Roach		echo "</div>";
57a25f0a04SGreg Roach
58a25f0a04SGreg Roach		$html->setXy(0, $html->getY() + $this->getFootnoteHeight($html));
59a25f0a04SGreg Roach	}
60a25f0a04SGreg Roach
61a25f0a04SGreg Roach	/**
62a25f0a04SGreg Roach	 * Calculates the Footnotes height
63a25f0a04SGreg Roach	 *
64a25f0a04SGreg Roach	 * @param ReportHtml $html
65a25f0a04SGreg Roach	 * @param integer    $cellWidth The width of the cell to use it for text wraping
66a25f0a04SGreg Roach	 *
67a25f0a04SGreg Roach	 * @return integer   Footnote height in points
68a25f0a04SGreg Roach	 */
69a25f0a04SGreg Roach	function getFootnoteHeight($html, $cellWidth = 0) {
70a25f0a04SGreg Roach		if ($html->getCurrentStyle() != $this->styleName) {
71a25f0a04SGreg Roach			$html->setCurrentStyle($this->styleName);
72a25f0a04SGreg Roach		}
73a25f0a04SGreg Roach
74a25f0a04SGreg Roach		if ($cellWidth > 0) {
75a25f0a04SGreg Roach			$this->text = $html->textWrap($this->text, $cellWidth);
76a25f0a04SGreg Roach		}
77a25f0a04SGreg Roach		$this->text = $this->text . "\n\n";
78a25f0a04SGreg Roach		$ct = substr_count($this->text, "\n");
79a25f0a04SGreg Roach		$fsize = $html->getCurrentStyleHeight();
80a25f0a04SGreg Roach		return ($fsize * $ct) * $html->cellHeightRatio;
81a25f0a04SGreg Roach	}
82a25f0a04SGreg Roach
83a25f0a04SGreg Roach	/**
84a25f0a04SGreg Roach	 * Get the width of text
85a25f0a04SGreg Roach	 * Breaks up a text into lines if needed
86a25f0a04SGreg Roach	 *
87a25f0a04SGreg Roach	 * @param ReportHtml $html
88a25f0a04SGreg Roach	 *
89a25f0a04SGreg Roach	 * @return array
90a25f0a04SGreg Roach	 */
91a25f0a04SGreg Roach	function getWidth($html) {
92a25f0a04SGreg Roach		// Setup the style name
93a25f0a04SGreg Roach		$html->setCurrentStyle("footnotenum");
94a25f0a04SGreg Roach
95a25f0a04SGreg Roach		// Check for the largest font size in the box
96a25f0a04SGreg Roach		$fsize = $html->getCurrentStyleHeight();
97a25f0a04SGreg Roach		if ($fsize > $html->largestFontHeight) {
98a25f0a04SGreg Roach			$html->largestFontHeight = $fsize;
99a25f0a04SGreg Roach		}
100a25f0a04SGreg Roach
101a25f0a04SGreg Roach		// Returns the Object if already numbered else false
102a25f0a04SGreg Roach		if (empty($this->num)) {
103a25f0a04SGreg Roach			$html->checkFootnote($this);
104a25f0a04SGreg Roach		}
105a25f0a04SGreg Roach
106a25f0a04SGreg Roach		// Get the line width for the text in points + a little margin
107a25f0a04SGreg Roach		$lw = $html->GetStringWidth($this->numText);
108a25f0a04SGreg Roach		// Line Feed counter - Number of lines in the text
109a25f0a04SGreg Roach		$lfct = $html->countLines($this->numText);
110a25f0a04SGreg Roach		// If there is still remaining wrap width...
111a25f0a04SGreg Roach		if ($this->wrapWidthRemaining > 0) {
112a25f0a04SGreg Roach			// Check with line counter too!
113a25f0a04SGreg Roach			if (($lw >= $this->wrapWidthRemaining) or ($lfct > 1)) {
114a25f0a04SGreg Roach				$newtext = "";
115a25f0a04SGreg Roach				$wrapWidthRemaining = $this->wrapWidthRemaining;
116a25f0a04SGreg Roach				$lines = explode("\n", $this->numText);
117a25f0a04SGreg Roach				// Go throught the text line by line
118a25f0a04SGreg Roach				foreach ($lines as $line) {
119a25f0a04SGreg Roach					// Line width in points + a little margin
120a25f0a04SGreg Roach					$lw = $html->GetStringWidth($line);
121a25f0a04SGreg Roach					// If the line has to be wraped
122a25f0a04SGreg Roach					if ($lw > $wrapWidthRemaining) {
123a25f0a04SGreg Roach						$words = explode(" ", $line);
124a25f0a04SGreg Roach						$addspace = count($words);
125a25f0a04SGreg Roach						$lw = 0;
126a25f0a04SGreg Roach						foreach ($words as $word) {
127a25f0a04SGreg Roach							$addspace--;
128a25f0a04SGreg Roach							$lw += $html->GetStringWidth($word . " ");
129a25f0a04SGreg Roach							if ($lw <= $wrapWidthRemaining) {
130a25f0a04SGreg Roach								$newtext .= $word;
131a25f0a04SGreg Roach								if ($addspace != 0) {
132a25f0a04SGreg Roach									$newtext .= " ";
133a25f0a04SGreg Roach								}
134a25f0a04SGreg Roach							} else {
135a25f0a04SGreg Roach								$lw = $html->GetStringWidth($word . " ");
136a25f0a04SGreg Roach								$newtext .= "\n$word";
137a25f0a04SGreg Roach								if ($addspace != 0) {
138a25f0a04SGreg Roach									$newtext .= " ";
139a25f0a04SGreg Roach								}
140a25f0a04SGreg Roach								// Reset the wrap width to the cell width
141a25f0a04SGreg Roach								$wrapWidthRemaining = $this->wrapWidthCell;
142a25f0a04SGreg Roach							}
143a25f0a04SGreg Roach						}
144a25f0a04SGreg Roach					} else {
145a25f0a04SGreg Roach						$newtext .= $line;
146a25f0a04SGreg Roach					}
147a25f0a04SGreg Roach					// Check the Line Feed counter
148a25f0a04SGreg Roach					if ($lfct > 1) {
149a25f0a04SGreg Roach						// Add a new line feed as long as it’s not the last line
150a25f0a04SGreg Roach						$newtext .= "\n";
151a25f0a04SGreg Roach						// Reset the line width
152a25f0a04SGreg Roach						$lw = 0;
153a25f0a04SGreg Roach						// Reset the wrap width to the cell width
154a25f0a04SGreg Roach						$wrapWidthRemaining = $this->wrapWidthCell;
155a25f0a04SGreg Roach					}
156a25f0a04SGreg Roach					$lfct--;
157a25f0a04SGreg Roach				}
158a25f0a04SGreg Roach				$this->numText = $newtext;
159a25f0a04SGreg Roach				$lfct = substr_count($this->numText, "\n");
160a25f0a04SGreg Roach				return array($lw, 1, $lfct);
161a25f0a04SGreg Roach			}
162a25f0a04SGreg Roach		}
163a25f0a04SGreg Roach		$l = 0;
164a25f0a04SGreg Roach		$lfct = substr_count($this->numText, "\n");
165a25f0a04SGreg Roach		if ($lfct > 0) {
166a25f0a04SGreg Roach			$l = 2;
167a25f0a04SGreg Roach		}
168a25f0a04SGreg Roach		return array($lw, $l, $lfct);
169a25f0a04SGreg Roach	}
170a25f0a04SGreg Roach}
171