ODF line generation : compat php < 7.4
This commit is contained in:
parent
06c64eea98
commit
e1c56650eb
@ -167,14 +167,13 @@ class Odf
|
||||
{
|
||||
$value = html_entity_decode($value, ENT_QUOTES | ENT_SUBSTITUTE | ENT_HTML401);
|
||||
|
||||
// fix breaklines...
|
||||
$value = str_replace("<br>", "<br />", $value);
|
||||
// fix breaklines.
|
||||
$value = preg_replace('/<[ ]*br[ ]*\/?>/', "<br />", $value);
|
||||
$convertedValue = $value;
|
||||
|
||||
// Check if the value includes html tags
|
||||
if ($this->_hasHtmlTag($value) === true) {
|
||||
// Note: allowing many tags is supported on PHP >7.4 . For older versions, this will strip all HTML tags.
|
||||
$value = strip_tags($value, ['<br>', '<strong>', '<b>', '<i>', '<em>', '<u>', '<s>', '<sub>', '<sup>', '<span>']);
|
||||
$value = strip_tags($value, '<br><strong><b><i><em><u><s><sub><sup><span>');
|
||||
|
||||
// Default styles for strong/b, i/em, u, s, sub & sup
|
||||
$automaticStyles = array(
|
||||
|
||||
@ -155,101 +155,87 @@ class ODFTest extends PHPUnit\Framework\TestCase
|
||||
'to_convert' => 'Simple string',
|
||||
'encode' => true,
|
||||
'charset' => null,
|
||||
'expected7.4' => 'Simple string',
|
||||
'expected7.3' => 'Simple string'
|
||||
'expected' => 'Simple string',
|
||||
],
|
||||
2 => [
|
||||
'to_convert' => 'Simple string',
|
||||
'encode' => false,
|
||||
'charset' => null,
|
||||
'expected7.4' => 'Simple string',
|
||||
'expected7.3' => 'Simple string'
|
||||
'expected' => 'Simple string',
|
||||
],
|
||||
3 => [
|
||||
'to_convert' => "Simple string\nwith line break",
|
||||
'encode' => true,
|
||||
'charset' => null,
|
||||
'expected7.4' => "Simple string<text:line-break/>with line break",
|
||||
'expected7.3' => "Simple string<text:line-break/>with line break"
|
||||
'expected' => "Simple string<text:line-break/>with line break",
|
||||
],
|
||||
4 => [
|
||||
'to_convert' => "Simple string\nwith line break",
|
||||
'encode' => false,
|
||||
'charset' => null,
|
||||
'expected7.4' => "Simple string<text:line-break/>with line break",
|
||||
'expected7.3' => "Simple string<text:line-break/>with line break"
|
||||
'expected' => "Simple string<text:line-break/>with line break",
|
||||
],
|
||||
// Special chars
|
||||
5 => [
|
||||
'to_convert' => 'One&two',
|
||||
'encode' => true,
|
||||
'charset' => null,
|
||||
'expected7.4' => 'One&two',
|
||||
'expected7.3' => 'One&two'
|
||||
'expected' => 'One&two',
|
||||
],
|
||||
6 => [
|
||||
'to_convert' => 'One&two',
|
||||
'encode' => false,
|
||||
'charset' => null,
|
||||
'expected7.4' => 'One&two',
|
||||
'expected7.3' => 'One&two'
|
||||
'expected' => 'One&two',
|
||||
],
|
||||
7 => [
|
||||
'to_convert' => "/a&él'èàüöç€Ğ~<>",
|
||||
'encode' => true,
|
||||
'charset' => null,
|
||||
'expected7.4' => utf8_encode("/a&él'èàüöç€Ğ~<>"),
|
||||
'expected7.3' => utf8_encode("/a&él'èàüöç€Ğ~<>")
|
||||
'expected' => utf8_encode("/a&él'èàüöç€Ğ~<>"),
|
||||
],
|
||||
8 => [
|
||||
'to_convert' => "/a&él'èàüöç€Ğ~<>",
|
||||
'encode' => false,
|
||||
'charset' => null,
|
||||
'expected7.4' => utf8_encode("/a&él'èàüöç€Ğ~<>"),
|
||||
'expected7.3' => utf8_encode("/a&él'èàüöç€Ğ~<>")
|
||||
'expected' => utf8_encode("/a&él'èàüöç€Ğ~<>"),
|
||||
],
|
||||
// special chars with non-default charset
|
||||
9 => [
|
||||
'to_convert' => "/a&él'èàüöç€Ğ~<>",
|
||||
'encode' => true,
|
||||
'charset' => 'UTF-16',
|
||||
'expected7.4' => "/a&él'èàüöç€Ğ~<>",
|
||||
'expected7.3' => "/a&él'èàüöç€Ğ~<>",
|
||||
'expected' => "/a&él'èàüöç€Ğ~<>",
|
||||
],
|
||||
10 => [
|
||||
'to_convert' => "/a&él'èàüöç€Ğ~<>",
|
||||
'encode' => false,
|
||||
'charset' => 'UTF-16', // When the charset differs from ISO-8859 string is not converted.
|
||||
'expected7.4' => "/a&él'èàüöç€Ğ~<>",
|
||||
'expected7.3' => "/a&él'èàüöç€Ğ~<>",
|
||||
'expected' => "/a&él'èàüöç€Ğ~<>",
|
||||
],
|
||||
11 => [
|
||||
'to_convert' => "Greater > than",
|
||||
'encode' => true,
|
||||
'charset' => null,
|
||||
'expected7.4' => utf8_encode("Greater > than"),
|
||||
'expected7.3' => utf8_encode("Greater > than"),
|
||||
'expected' => utf8_encode("Greater > than"),
|
||||
],
|
||||
12 => [
|
||||
'to_convert' => "Greater > than",
|
||||
'encode' => false,
|
||||
'charset' => null,
|
||||
'expected7.4' => utf8_encode("Greater > than"),
|
||||
'expected7.3' => utf8_encode("Greater > than"),
|
||||
'expected' => utf8_encode("Greater > than"),
|
||||
],
|
||||
13 => [
|
||||
'to_convert' => "Smaller < than",
|
||||
'encode' => true,
|
||||
'charset' => null,
|
||||
'expected7.4' => utf8_encode("Smaller < than"),
|
||||
'expected7.3' => utf8_encode("Smaller < than"),
|
||||
'expected' => utf8_encode("Smaller < than"),
|
||||
],
|
||||
14 => [
|
||||
'to_convert' => "Smaller < than",
|
||||
'encode' => false,
|
||||
'charset' => null,
|
||||
'expected7.4' => utf8_encode("Smaller < than"),
|
||||
'expected7.3' => utf8_encode("Smaller < than"),
|
||||
'expected' => utf8_encode("Smaller < than"),
|
||||
],
|
||||
/** HTML **/
|
||||
// break lines
|
||||
@ -257,65 +243,56 @@ class ODFTest extends PHPUnit\Framework\TestCase
|
||||
'to_convert' => "Break<br>line",
|
||||
'encode' => true,
|
||||
'charset' => null,
|
||||
'expected7.4' => utf8_encode("Break<text:line-break/>line"),
|
||||
'expected7.3' => utf8_encode("Breakline"),
|
||||
'expected' => utf8_encode("Break<text:line-break/>line"),
|
||||
],
|
||||
16 => [
|
||||
'to_convert' => "Break<br>line",
|
||||
'encode' => false,
|
||||
'charset' => null,
|
||||
'expected7.4' => utf8_encode("Break<text:line-break/>line"),
|
||||
'expected7.3' => utf8_encode("Breakline"),
|
||||
'expected' => utf8_encode("Break<text:line-break/>line"),
|
||||
],
|
||||
17 => [
|
||||
'to_convert' => "Break<br />line",
|
||||
'encode' => true,
|
||||
'charset' => null,
|
||||
'expected7.4' => utf8_encode("Break<text:line-break/>line"),
|
||||
'expected7.3' => utf8_encode("Breakline"),
|
||||
'expected' => utf8_encode("Break<text:line-break/>line"),
|
||||
],
|
||||
18 => [
|
||||
'to_convert' => "Break<br />line",
|
||||
'encode' => false,
|
||||
'charset' => null,
|
||||
'expected7.4' => utf8_encode("Break<text:line-break/>line"),
|
||||
'expected7.3' => utf8_encode("Breakline"),
|
||||
'expected' => utf8_encode("Break<text:line-break/>line"),
|
||||
],
|
||||
// HTML tags
|
||||
19 => [
|
||||
'to_convert' => "text with <strong>strong, </strong><em>emphasis</em> and <u>underlined</u> words with <i>it@lic sp&ciàlchärs éè l'</i>",
|
||||
'encode' => false,
|
||||
'charset' => 'UTF-8',
|
||||
'expected7.4' => 'text with <text:span text:style-name="boldText">strong, </text:span><text:span text:style-name="italicText">emphasis</text:span> and <text:span text:style-name="underlineText">underlined</text:span> words with <text:span text:style-name="italicText">it@lic sp&ciàlchärs éè l\'</text:span>',
|
||||
'expected7.3' => 'text with strong, emphasis and underlined words with it@lic sp&ciàlchärs éè l\'',
|
||||
'expected' => 'text with <text:span text:style-name="boldText">strong, </text:span><text:span text:style-name="italicText">emphasis</text:span> and <text:span text:style-name="underlineText">underlined</text:span> words with <text:span text:style-name="italicText">it@lic sp&ciàlchärs éè l\'</text:span>',
|
||||
],
|
||||
20 => [
|
||||
'to_convert' => "text with <strong>strong, </strong><em>emphasis</em> and <u>underlined</u> words with <i>it@lic sp&ciàlchärs éè l'</i>",
|
||||
'encode' => true,
|
||||
'charset' => 'UTF-8',
|
||||
'expected7.4' => 'text with <text:span text:style-name="boldText">strong, </text:span><text:span text:style-name="italicText">emphasis</text:span> and <text:span text:style-name="underlineText">underlined</text:span> words with <text:span text:style-name="italicText">it@lic sp&ciàlchärs éè l'</text:span>',
|
||||
'expected7.3' => 'text with strong, emphasis and underlined words with it@lic sp&ciàlchärs éè l'',
|
||||
'expected' => 'text with <text:span text:style-name="boldText">strong, </text:span><text:span text:style-name="italicText">emphasis</text:span> and <text:span text:style-name="underlineText">underlined</text:span> words with <text:span text:style-name="italicText">it@lic sp&ciàlchärs éè l'</text:span>',
|
||||
],
|
||||
21 => [
|
||||
'to_convert' => "text with <strong>strong, </strong><em>emphasis</em> and <u>underlined</u> words with <i>it@lic sp&ciàlchärs éè l'</i>",
|
||||
'encode' => false,
|
||||
'charset' => null,
|
||||
'expected7.4' => utf8_encode('text with <text:span text:style-name="boldText">strong, </text:span><text:span text:style-name="italicText">emphasis</text:span> and <text:span text:style-name="underlineText">underlined</text:span> words with <text:span text:style-name="italicText">it@lic sp&ciàlchärs éè l\'</text:span>'),
|
||||
'expected7.3' => utf8_encode('text with strong, emphasis and underlined words with it@lic sp&ciàlchärs éè l\''),
|
||||
'expected' => utf8_encode('text with <text:span text:style-name="boldText">strong, </text:span><text:span text:style-name="italicText">emphasis</text:span> and <text:span text:style-name="underlineText">underlined</text:span> words with <text:span text:style-name="italicText">it@lic sp&ciàlchärs éè l\'</text:span>'),
|
||||
],
|
||||
22 => [
|
||||
'to_convert' => "text with <strong>strong, </strong><em>emphasis</em> and <u>underlined</u> words with <i>it@lic sp&ciàlchärs éè l'</i>",
|
||||
'encode' => true,
|
||||
'charset' => null,
|
||||
'expected7.4' => utf8_encode('text with <text:span text:style-name="boldText">strong, </text:span><text:span text:style-name="italicText">emphasis</text:span> and <text:span text:style-name="underlineText">underlined</text:span> words with <text:span text:style-name="italicText">it@lic sp&ciàlchärs éè l'</text:span>'),
|
||||
'expected7.3' => utf8_encode('text with strong, emphasis and underlined words with it@lic sp&ciàlchärs éè l''),
|
||||
'expected' => utf8_encode('text with <text:span text:style-name="boldText">strong, </text:span><text:span text:style-name="italicText">emphasis</text:span> and <text:span text:style-name="underlineText">underlined</text:span> words with <text:span text:style-name="italicText">it@lic sp&ciàlchärs éè l'</text:span>'),
|
||||
],
|
||||
23 => [
|
||||
'to_convert' => "text with <strong>intricated<u>tags</u></strong>",
|
||||
'encode' => true,
|
||||
'charset' => null,
|
||||
'expected7.4' => utf8_encode('text with <text:span text:style-name="boldText">intricated<text:span text:style-name="underlineText">tags</text:span></text:span>'),
|
||||
'expected7.3' => utf8_encode('text with intricatedtags'),
|
||||
'expected' => utf8_encode('text with <text:span text:style-name="boldText">intricated<text:span text:style-name="underlineText">tags</text:span></text:span>'),
|
||||
],
|
||||
|
||||
// One can also pass html-encoded string to the method
|
||||
@ -323,36 +300,31 @@ class ODFTest extends PHPUnit\Framework\TestCase
|
||||
'to_convert' => 'One&two',
|
||||
'encode' => true,
|
||||
'charset' => null,
|
||||
'expected7.4' => 'One&two',
|
||||
'expected7.3' => 'One&two'
|
||||
'expected' => 'One&two',
|
||||
],
|
||||
25 => [
|
||||
'to_convert' => "text with <strong>strong, </strong><em>emphasis</em> and <u>underlined</u> words with <i>it@lic sp&ciàlchärs éè l'</i>",
|
||||
'encode' => false,
|
||||
'charset' => 'UTF-8',
|
||||
'expected7.4' => 'text with <text:span text:style-name="boldText">strong, </text:span><text:span text:style-name="italicText">emphasis</text:span> and <text:span text:style-name="underlineText">underlined</text:span> words with <text:span text:style-name="italicText">it@lic sp&ciàlchärs éè l\'</text:span>',
|
||||
'expected7.3' => 'text with strong, emphasis and underlined words with it@lic sp&ciàlchärs éè l\'',
|
||||
'expected' => 'text with <text:span text:style-name="boldText">strong, </text:span><text:span text:style-name="italicText">emphasis</text:span> and <text:span text:style-name="underlineText">underlined</text:span> words with <text:span text:style-name="italicText">it@lic sp&ciàlchärs éè l\'</text:span>',
|
||||
],
|
||||
26 => [
|
||||
'to_convert' => "text with <strong>strong, </strong><em>emphasis</em> and <u>underlined</u> words with <i>it@lic sp&ciàlchärs éè l'</i>",
|
||||
'encode' => true,
|
||||
'charset' => 'UTF-8',
|
||||
'expected7.4' => 'text with <text:span text:style-name="boldText">strong, </text:span><text:span text:style-name="italicText">emphasis</text:span> and <text:span text:style-name="underlineText">underlined</text:span> words with <text:span text:style-name="italicText">it@lic sp&ciàlchärs éè l'</text:span>',
|
||||
'expected7.3' => 'text with strong, emphasis and underlined words with it@lic sp&ciàlchärs éè l'',
|
||||
'expected' => 'text with <text:span text:style-name="boldText">strong, </text:span><text:span text:style-name="italicText">emphasis</text:span> and <text:span text:style-name="underlineText">underlined</text:span> words with <text:span text:style-name="italicText">it@lic sp&ciàlchärs éè l'</text:span>',
|
||||
],
|
||||
27 => [
|
||||
'to_convert' => "text with <strong>strong, </strong><em>emphasis</em> and <u>underlined</u> words with <i>it@lic sp&ciàlchärs éè l'</i>",
|
||||
'encode' => false,
|
||||
'charset' => null,
|
||||
'expected7.4' => utf8_encode('text with <text:span text:style-name="boldText">strong, </text:span><text:span text:style-name="italicText">emphasis</text:span> and <text:span text:style-name="underlineText">underlined</text:span> words with <text:span text:style-name="italicText">it@lic sp&ciàlchärs éè l\'</text:span>'),
|
||||
'expected7.3' => utf8_encode('text with strong, emphasis and underlined words with it@lic sp&ciàlchärs éè l\''),
|
||||
'expected' => utf8_encode('text with <text:span text:style-name="boldText">strong, </text:span><text:span text:style-name="italicText">emphasis</text:span> and <text:span text:style-name="underlineText">underlined</text:span> words with <text:span text:style-name="italicText">it@lic sp&ciàlchärs éè l\'</text:span>'),
|
||||
],
|
||||
28 => [
|
||||
'to_convert' => "text with <strong>strong, </strong><em>emphasis</em> and <u>underlined</u> words with <i>it@lic sp&ciàlchärs éè l'</i>",
|
||||
'encode' => true,
|
||||
'charset' => null,
|
||||
'expected7.4' => utf8_encode('text with <text:span text:style-name="boldText">strong, </text:span><text:span text:style-name="italicText">emphasis</text:span> and <text:span text:style-name="underlineText">underlined</text:span> words with <text:span text:style-name="italicText">it@lic sp&ciàlchärs éè l'</text:span>'),
|
||||
'expected7.3' => utf8_encode('text with strong, emphasis and underlined words with it@lic sp&ciàlchärs éè l''),
|
||||
'expected' => utf8_encode('text with <text:span text:style-name="boldText">strong, </text:span><text:span text:style-name="italicText">emphasis</text:span> and <text:span text:style-name="underlineText">underlined</text:span> words with <text:span text:style-name="italicText">it@lic sp&ciàlchärs éè l'</text:span>'),
|
||||
],
|
||||
|
||||
// // TODO custom styles are not tested for now : the custom style have a custom ID based on time. Not random, but hard to mock or predict. generated in _replaceHtmlWithOdtTag() case 'span'.
|
||||
@ -360,7 +332,7 @@ class ODFTest extends PHPUnit\Framework\TestCase
|
||||
// 'to_convert' => '123 <span style="color:#e74c3c">trucmachin > truc < troc > trac</span>bla bla',
|
||||
// 'encode' => true,
|
||||
// 'charset' => 'UTF-8',
|
||||
// 'expected7.4' => "123 <text:span text:style-name="customStyle1668592427018">trucmachin > truc < troc > trac</text:span>bla bla'",
|
||||
// 'expected' => "123 <text:span text:style-name="customStyle1668592427018">trucmachin > truc < troc > trac</text:span>bla bla'",
|
||||
// ],
|
||||
|
||||
/* Tests that can evolve */
|
||||
@ -371,23 +343,20 @@ class ODFTest extends PHPUnit\Framework\TestCase
|
||||
'to_convert' => '123 <a href="/test.php">trucmachin > truc < troc > trac</a>bla bla',
|
||||
'encode' => true,
|
||||
'charset' => null,
|
||||
'expected7.4' => "123 trucmachin > truc < troc > tracbla bla",
|
||||
'expected7.3' => "123 trucmachin > truc < troc > tracbla bla",
|
||||
'expected' => "123 trucmachin > truc < troc > tracbla bla",
|
||||
],
|
||||
30 => [
|
||||
'to_convert' => '123 <h3>Title</h3> bla',
|
||||
'encode' => true,
|
||||
'charset' => null,
|
||||
'expected7.4' => "123 Title bla",
|
||||
'expected7.3' => "123 Title bla",
|
||||
'expected' => "123 Title bla",
|
||||
],
|
||||
// HTML should not take \n into account, but only <br />.
|
||||
31 => [
|
||||
'to_convert' => "text with <strong>strong text </strong>, a line\nbreak and <u>underlined</u> words with <i>it@lic sp&ciàlchärs éè l'</i>",
|
||||
'encode' => false,
|
||||
'charset' => 'UTF-8',
|
||||
'expected7.4' => 'text with <text:span text:style-name="boldText">strong text </text:span>, a line'."\n".'break and <text:span text:style-name="underlineText">underlined</text:span> words with <text:span text:style-name="italicText">it@lic sp&ciàlchärs éè l\'</text:span>',
|
||||
'expected7.3' => 'text with strong text , a line'."\n".'break and underlined words with it@lic sp&ciàlchärs éè l\'',
|
||||
'expected' => 'text with <text:span text:style-name="boldText">strong text </text:span>, a line'."\n".'break and <text:span text:style-name="underlineText">underlined</text:span> words with <text:span text:style-name="italicText">it@lic sp&ciàlchärs éè l\'</text:span>',
|
||||
],
|
||||
];
|
||||
|
||||
@ -400,11 +369,7 @@ class ODFTest extends PHPUnit\Framework\TestCase
|
||||
} else {
|
||||
$res = $odf->convertVarToOdf($case['to_convert'], $case['encode']);
|
||||
}
|
||||
if (version_compare(phpversion(), '7.4.0', '>=')) {
|
||||
$this->assertEquals($res, $case['expected7.4']);
|
||||
} else {
|
||||
$this->assertEquals($res, $case['expected7.3']);
|
||||
}
|
||||
$this->assertEquals($res, $case['expected']);
|
||||
}
|
||||
|
||||
print __METHOD__." result=".$result."\n";
|
||||
|
||||
Loading…
Reference in New Issue
Block a user