mirror of
https://github.com/ezyang/htmlpurifier.git
synced 2025-01-18 11:41:52 +00:00
Implement shorthand CSS property border.
git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@324 48356398-32a2-884e-a903-53898d9a118a
This commit is contained in:
parent
ffe39d7f30
commit
692a9abc0f
2
NEWS
2
NEWS
@ -5,7 +5,7 @@ NEWS ( CHANGELOG and HISTORY ) HTMLPurifier
|
|||||||
- Fixed broken numeric entity conversion
|
- Fixed broken numeric entity conversion
|
||||||
- Malformed UTF-8 and non-SGML character detection and cleaning implemented
|
- Malformed UTF-8 and non-SGML character detection and cleaning implemented
|
||||||
- API documentation completed
|
- API documentation completed
|
||||||
- Shorthand CSS properties implemented: font
|
- Shorthand CSS properties implemented: font, border
|
||||||
- Basic color keywords translated into hexadecimal values
|
- Basic color keywords translated into hexadecimal values
|
||||||
|
|
||||||
1.0.0beta, released 2006-08-16
|
1.0.0beta, released 2006-08-16
|
||||||
|
1
TODO
1
TODO
@ -4,7 +4,6 @@ Core:
|
|||||||
- Finish table and shorthand CSS attributes
|
- Finish table and shorthand CSS attributes
|
||||||
- border-collapse, caption-side, empty-cells, table-layout, vertical-align
|
- border-collapse, caption-side, empty-cells, table-layout, vertical-align
|
||||||
- background (and friends)
|
- background (and friends)
|
||||||
- border, border-*
|
|
||||||
- list-style
|
- list-style
|
||||||
- Implement all non-essential attribute transforms
|
- Implement all non-essential attribute transforms
|
||||||
- Microsoft Word HTML cleaning
|
- Microsoft Word HTML cleaning
|
||||||
|
@ -135,11 +135,11 @@ thead th {text-align:left;padding:0.1em;background-color:#EEE;}
|
|||||||
<tr><th colspan="2">Standard</th></tr>
|
<tr><th colspan="2">Standard</th></tr>
|
||||||
<tr class="css1 impl-yes"><td>background-color</td><td>COMPOSITE(<color>, transparent)</td></tr>
|
<tr class="css1 impl-yes"><td>background-color</td><td>COMPOSITE(<color>, transparent)</td></tr>
|
||||||
<tr class="css1"><td>background</td><td>SHORTHAND</td></tr>
|
<tr class="css1"><td>background</td><td>SHORTHAND</td></tr>
|
||||||
<tr class="css1"><td>border</td><td>SHORTHAND, MULTIPLE</td></tr>
|
<tr class="css1 impl-yes"><td>border</td><td>SHORTHAND, MULTIPLE</td></tr>
|
||||||
<tr class="css1 impl-yes"><td>border-color</td><td>MULTIPLE</td></tr>
|
<tr class="css1 impl-yes"><td>border-color</td><td>MULTIPLE</td></tr>
|
||||||
<tr class="css1 impl-yes"><td>border-style</td><td>MULTIPLE</td></tr>
|
<tr class="css1 impl-yes"><td>border-style</td><td>MULTIPLE</td></tr>
|
||||||
<tr class="css1 impl-yes"><td>border-width</td><td>MULTIPLE</td></tr>
|
<tr class="css1 impl-yes"><td>border-width</td><td>MULTIPLE</td></tr>
|
||||||
<tr class="css1"><td>border-*</td><td>SHORTHAND</td></tr>
|
<tr class="css1 impl-yes"><td>border-*</td><td>SHORTHAND</td></tr>
|
||||||
<tr class="impl-yes"><td>border-*-color</td><td>COMPOSITE(<color>, transparent)</td></tr>
|
<tr class="impl-yes"><td>border-*-color</td><td>COMPOSITE(<color>, transparent)</td></tr>
|
||||||
<tr class="impl-yes"><td>border-*-style</td><td>ENUM(none, hidden, dotted, dashed,
|
<tr class="impl-yes"><td>border-*-style</td><td>ENUM(none, hidden, dotted, dashed,
|
||||||
solid, double, groove, ridge, inset, outset)</td></tr>
|
solid, double, groove, ridge, inset, outset)</td></tr>
|
||||||
|
45
library/HTMLPurifier/AttrDef/Border.php
Normal file
45
library/HTMLPurifier/AttrDef/Border.php
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
require_once 'HTMLPurifier/AttrDef.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Validates the border property as defined by CSS.
|
||||||
|
*/
|
||||||
|
class HTMLPurifier_AttrDef_Border extends HTMLPurifier_AttrDef
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Local copy of properties this property is shorthand for.
|
||||||
|
*/
|
||||||
|
var $info = array();
|
||||||
|
|
||||||
|
function HTMLPurifier_AttrDef_Border() {
|
||||||
|
$def = HTMLPurifier_CSSDefinition::instance();
|
||||||
|
$this->info['border-width'] = $def->info['border-width'];
|
||||||
|
$this->info['border-style'] = $def->info['border-style'];
|
||||||
|
$this->info['border-top-color'] = $def->info['border-top-color'];
|
||||||
|
}
|
||||||
|
|
||||||
|
function validate($string, $config, &$context) {
|
||||||
|
$string = $this->parseCDATA($string);
|
||||||
|
// we specifically will not support rgb() syntax with spaces
|
||||||
|
$bits = explode(' ', $string);
|
||||||
|
$done = array(); // segments we've finished
|
||||||
|
$ret = ''; // return value
|
||||||
|
foreach ($bits as $bit) {
|
||||||
|
foreach ($this->info as $propname => $validator) {
|
||||||
|
if (isset($done[$propname])) continue;
|
||||||
|
$r = $validator->validate($bit, $config, &$context);
|
||||||
|
if ($r !== false) {
|
||||||
|
$ret .= $r . ' ';
|
||||||
|
$done[$propname] = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return rtrim($ret);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
@ -9,6 +9,7 @@ require_once 'HTMLPurifier/AttrDef/Multiple.php';
|
|||||||
require_once 'HTMLPurifier/AttrDef/TextDecoration.php';
|
require_once 'HTMLPurifier/AttrDef/TextDecoration.php';
|
||||||
require_once 'HTMLPurifier/AttrDef/FontFamily.php';
|
require_once 'HTMLPurifier/AttrDef/FontFamily.php';
|
||||||
require_once 'HTMLPurifier/AttrDef/Font.php';
|
require_once 'HTMLPurifier/AttrDef/Font.php';
|
||||||
|
require_once 'HTMLPurifier/AttrDef/Border.php';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Defines allowed CSS attributes and what their values are.
|
* Defines allowed CSS attributes and what their values are.
|
||||||
@ -170,6 +171,13 @@ class HTMLPurifier_CSSDefinition
|
|||||||
// a CSSDefinition object
|
// a CSSDefinition object
|
||||||
$this->info['font'] = new HTMLPurifier_AttrDef_Font();
|
$this->info['font'] = new HTMLPurifier_AttrDef_Font();
|
||||||
|
|
||||||
|
// same here
|
||||||
|
$this->info['border'] =
|
||||||
|
$this->info['border-bottom'] =
|
||||||
|
$this->info['border-top'] =
|
||||||
|
$this->info['border-left'] =
|
||||||
|
$this->info['border-right'] = new HTMLPurifier_AttrDef_Border();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
21
tests/HTMLPurifier/AttrDef/BorderTest.php
Normal file
21
tests/HTMLPurifier/AttrDef/BorderTest.php
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
require_once 'HTMLPurifier/AttrDef/Border.php';
|
||||||
|
|
||||||
|
class HTMLPurifier_AttrDef_BorderTest extends HTMLPurifier_AttrDef_PixelsTest
|
||||||
|
{
|
||||||
|
|
||||||
|
function test() {
|
||||||
|
|
||||||
|
$this->def = new HTMLPurifier_AttrDef_Border();
|
||||||
|
|
||||||
|
$this->assertDef('thick solid red', 'thick solid #F00');
|
||||||
|
$this->assertDef('thick solid');
|
||||||
|
$this->assertDef('solid red', 'solid #F00');
|
||||||
|
$this->assertDef('1px solid #000');
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
@ -60,7 +60,9 @@ class HTMLPurifier_AttrDef_CSSTest extends HTMLPurifier_AttrDefHarness
|
|||||||
$this->assertDef('text-decoration:underline;');
|
$this->assertDef('text-decoration:underline;');
|
||||||
$this->assertDef('font-family:sans-serif;');
|
$this->assertDef('font-family:sans-serif;');
|
||||||
$this->assertDef('font-family:Gill, \'Times New Roman\', sans-serif;');
|
$this->assertDef('font-family:Gill, \'Times New Roman\', sans-serif;');
|
||||||
//$this->assertDef('font:12px serif;');
|
$this->assertDef('font:12px serif;');
|
||||||
|
$this->assertDef('border:1px solid #000;');
|
||||||
|
$this->assertDef('border-bottom:2em double #FF00FA;');
|
||||||
|
|
||||||
// duplicates
|
// duplicates
|
||||||
$this->assertDef('text-align:right;text-align:left;',
|
$this->assertDef('text-align:right;text-align:left;',
|
||||||
|
@ -76,6 +76,7 @@ $test_files[] = 'AttrDef/HostTest.php';
|
|||||||
$test_files[] = 'AttrDef/IPv4Test.php';
|
$test_files[] = 'AttrDef/IPv4Test.php';
|
||||||
$test_files[] = 'AttrDef/IPv6Test.php';
|
$test_files[] = 'AttrDef/IPv6Test.php';
|
||||||
$test_files[] = 'AttrDef/FontTest.php';
|
$test_files[] = 'AttrDef/FontTest.php';
|
||||||
|
$test_files[] = 'AttrDef/BorderTest.php';
|
||||||
$test_files[] = 'IDAccumulatorTest.php';
|
$test_files[] = 'IDAccumulatorTest.php';
|
||||||
$test_files[] = 'TagTransformTest.php';
|
$test_files[] = 'TagTransformTest.php';
|
||||||
$test_files[] = 'AttrTransform/LangTest.php';
|
$test_files[] = 'AttrTransform/LangTest.php';
|
||||||
|
Loading…
Reference in New Issue
Block a user