]> git.mxchange.org Git - friendica.git/blob - include/html2plain.php
bcdf89c2cc9b5ef1da0197ae5f2af3a1dda078c1
[friendica.git] / include / html2plain.php
1 <?php
2 require_once("include/html2bbcode.php");
3
4 function breaklines($line, $level, $wraplength = 75)
5 {
6
7         if ($wraplength == 0)
8                 $wraplength = 2000000;
9
10         //      return($line);
11
12         $wraplen = $wraplength-$level;
13
14         $newlines = array();
15
16         do {
17                 $oldline = $line;
18
19                 $subline = substr($line, 0, $wraplen);
20
21                 $pos = strrpos($subline, ' ');
22
23                 if ($pos == 0)
24                         $pos = strpos($line, ' ');
25
26                 if (($pos > 0) and strlen($line) > $wraplen) {
27                         $newline = trim(substr($line, 0, $pos));
28                         if ($level > 0)
29                                 $newline = str_repeat(">", $level).' '.$newline;
30
31                         $newlines[] = $newline." ";
32                         $line = substr($line, $pos+1);
33                 }
34
35         } while ((strlen($line) > $wraplen) and !($oldline == $line));
36
37         if ($level > 0)
38                 $line = str_repeat(">", $level).' '.$line;
39
40         $newlines[] = $line;
41
42
43         return(implode($newlines, "\n"));
44 }
45
46 function quotelevel($message, $wraplength = 75)
47 {
48         $lines = explode("\n", $message);
49
50         $newlines = array();
51         $level = 0;
52         foreach($lines as $line) {;
53                 $line = trim($line);
54                 $startquote = false;
55                 while (strpos("*".$line, '[quote]') > 0) {
56                         $level++;
57                         $pos = strpos($line, '[quote]');
58                         $line = substr($line, 0, $pos).substr($line, $pos+7);
59                         $startquote = true;
60                 }
61
62                 $currlevel = $level;
63
64                 while (strpos("*".$line, '[/quote]') > 0) {
65                         $level--;
66                         if ($level < 0)
67                                 $level = 0;
68
69                         $pos = strpos($line, '[/quote]');
70                         $line = substr($line, 0, $pos).substr($line, $pos+8);
71                 }
72
73                 if (!$startquote or ($line != ''))
74                         $newlines[] = breaklines($line, $currlevel, $wraplength);
75         }
76         return(implode($newlines, "\n"));
77 }
78
79 function collecturls($message) {
80         $pattern = '/<a.*?href="(.*?)".*?>(.*?)<\/a>/is';
81         preg_match_all($pattern, $message, $result, PREG_SET_ORDER);
82
83         $urls = array();
84         foreach ($result as $treffer) {
85
86                 $ignore = false;
87
88                 // A list of some links that should be ignored
89                 $list = array("/user/", "/tag/", "/group/", "/profile/", "/search?search=", "/search?tag=", "mailto:", "/u/", "/node/",
90                                 "//facebook.com/profile.php?id=", "//plus.google.com/", "//twitter.com/");
91                 foreach ($list as $listitem)
92                         if (strpos($treffer[1], $listitem) !== false)
93                                 $ignore = true;
94
95                 if ((strpos($treffer[1], "//twitter.com/") !== false) and (strpos($treffer[1], "/status/") !== false))
96                                 $ignore = false;
97
98                 if ((strpos($treffer[1], "//plus.google.com/") !== false) and (strpos($treffer[1], "/posts") !== false))
99                                 $ignore = false;
100
101                 if ((strpos($treffer[1], "//plus.google.com/") !== false) and (strpos($treffer[1], "/photos") !== false))
102                                 $ignore = false;
103
104                 if (!$ignore)
105                         $urls[$treffer[1]] = $treffer[1];
106         }
107         return($urls);
108 }
109
110 function html2plain($html, $wraplength = 75, $compact = false)
111 {
112         global $lang;
113
114         $message = str_replace("\r", "", $html);
115
116         // replace all hashtag addresses
117         if (get_config("system", "remove_hashtags_on_export")) {
118                 $pattern = '/#<a.*?href="(.*?)".*?>(.*?)<\/a>/is';
119                 $message = preg_replace($pattern, '#$2', $message);
120         }
121
122         $doc = new DOMDocument();
123         $doc->preserveWhiteSpace = false;
124
125         $message = mb_convert_encoding($message, 'HTML-ENTITIES', "UTF-8");
126
127         @$doc->loadHTML($message);
128
129         $xpath = new DomXPath($doc);
130         $list = $xpath->query("//pre");
131         foreach ($list as $node) {
132                 $node->nodeValue = str_replace("\n", "\r", $node->nodeValue);
133         }
134
135         $message = $doc->saveHTML();
136         $message = str_replace(array("\n<", ">\n", "\r", "\n", "\xC3\x82\xC2\xA0"), array("<", ">", "<br>", " ", ""), $message);
137         $message = preg_replace('= [\s]*=i', " ", $message);
138
139         // Collecting all links
140         $urls = collecturls($message);
141
142         @$doc->loadHTML($message);
143
144         node2bbcode($doc, 'html', array(), '', '');
145         node2bbcode($doc, 'body', array(), '', '');
146
147         // MyBB-Auszeichnungen
148         /*
149         node2bbcode($doc, 'span', array('style'=>'text-decoration: underline;'), '_', '_');
150         node2bbcode($doc, 'span', array('style'=>'font-style: italic;'), '/', '/');
151         node2bbcode($doc, 'span', array('style'=>'font-weight: bold;'), '*', '*');
152
153         node2bbcode($doc, 'strong', array(), '*', '*');
154         node2bbcode($doc, 'b', array(), '*', '*');
155         node2bbcode($doc, 'i', array(), '/', '/');
156         node2bbcode($doc, 'u', array(), '_', '_');
157         */
158
159         if ($compact)
160                 node2bbcode($doc, 'blockquote', array(), "»", "«");
161         else
162                 node2bbcode($doc, 'blockquote', array(), '[quote]', "[/quote]\n");
163
164         node2bbcode($doc, 'br', array(), "\n", '');
165
166         node2bbcode($doc, 'span', array(), "", "");
167         node2bbcode($doc, 'pre', array(), "", "");
168         node2bbcode($doc, 'div', array(), "\r", "\r");
169         node2bbcode($doc, 'p', array(), "\n", "\n");
170
171         //node2bbcode($doc, 'ul', array(), "\n[list]", "[/list]\n");
172         //node2bbcode($doc, 'ol', array(), "\n[list=1]", "[/list]\n");
173         node2bbcode($doc, 'li', array(), "\n* ", "\n");
174
175         node2bbcode($doc, 'hr', array(), "\n".str_repeat("-", 70)."\n", "");
176
177         node2bbcode($doc, 'tr', array(), "\n", "");
178         node2bbcode($doc, 'td', array(), "\t", "");
179
180         node2bbcode($doc, 'h1', array(), "\n\n*", "*\n");
181         node2bbcode($doc, 'h2', array(), "\n\n*", "*\n");
182         node2bbcode($doc, 'h3', array(), "\n\n*", "*\n");
183         node2bbcode($doc, 'h4', array(), "\n\n*", "*\n");
184         node2bbcode($doc, 'h5', array(), "\n\n*", "*\n");
185         node2bbcode($doc, 'h6', array(), "\n\n*", "*\n");
186
187         // Problem: there is no reliable way to detect if it is a link to a tag or profile
188         //node2bbcode($doc, 'a', array('href'=>'/(.+)/'), ' $1 ', '', true);
189         node2bbcode($doc, 'a', array('href'=>'/(.+)/', 'rel'=>'oembed'), ' $1 ', '', true);
190         //node2bbcode($doc, 'img', array('alt'=>'/(.+)/'), '$1', '');
191         //node2bbcode($doc, 'img', array('title'=>'/(.+)/'), '$1', '');
192         //node2bbcode($doc, 'img', array(), '', '');
193         if (!$compact)
194                 node2bbcode($doc, 'img', array('src'=>'/(.+)/'), '[img]$1', '[/img]');
195         else
196                 node2bbcode($doc, 'img', array('src'=>'/(.+)/'), '', '');
197
198         node2bbcode($doc, 'iframe', array('src'=>'/(.+)/'), ' $1 ', '', true);
199
200         $message = $doc->saveHTML();
201
202         if (!$compact) {
203                 $message = str_replace("[img]", "", $message);
204                 $message = str_replace("[/img]", "", $message);
205         }
206
207         // was ersetze ich da?
208         // Irgendein stoerrisches UTF-Zeug
209         $message = str_replace(chr(194).chr(160), ' ', $message);
210
211         $message = str_replace("&nbsp;", " ", $message);
212
213         // Aufeinanderfolgende DIVs
214         $message = preg_replace('=\r *\r=i', "\n", $message);
215         $message = str_replace("\r", "\n", $message);
216
217         $message = strip_tags($message);
218
219         $message = html_entity_decode($message, ENT_QUOTES, 'UTF-8');
220
221         if (!$compact AND ($message != "")) {
222                 $counter = 1;
223                 foreach ($urls as $id=>$url)
224                         if (strpos($message, $url) === false)
225                                 $message .= "\n".$url." ";
226                                 //$message .= "\n[".($counter++)."] ".$url;
227         }
228
229         $message = str_replace("\n«", "«\n", $message);
230         $message = str_replace("»\n", "\n»", $message);
231
232         do {
233                 $oldmessage = $message;
234                 $message = str_replace("\n\n\n", "\n\n", $message);
235         } while ($oldmessage != $message);
236
237         $message = quotelevel(trim($message), $wraplength);
238
239         return(trim($message));
240 }
241