Fixing anchor selection

This commit is contained in:
Daniel Hensby 2015-11-18 16:26:26 +00:00
parent 1a6655b2e2
commit 2dd8d5e518
3 changed files with 45 additions and 3 deletions

View File

@ -581,8 +581,12 @@ class HtmlEditorField_Toolbar extends RequestHandler {
} }
// Similar to the regex found in HtmlEditorField.js / getAnchors method. // Similar to the regex found in HtmlEditorField.js / getAnchors method.
if (preg_match_all("/\s(name|id)=\"([^\"]+?)\"|\s(name|id)='([^']+?)'/im", $page->Content, $matches)) { if (preg_match_all(
$anchors = array_filter(array_merge($matches[2], $matches[4])); "/\s+(name|id)\s*=\s*([\"'])([^\\2\s>]*?)\\2|\s+(name|id)\s*=\s*([^\"']+)[\s +>]/im",
$page->Content,
$matches
)) {
$anchors = array_filter(array_merge($matches[3], $matches[5]));
} }
} else { } else {

View File

@ -716,7 +716,8 @@ ss.editorWrappers['default'] = ss.editorWrappers.tinyMCE;
// http://www.w3.org/TR/1999/REC-html401-19991224/struct/links.html#h-12.2 // http://www.w3.org/TR/1999/REC-html401-19991224/struct/links.html#h-12.2
if(ed) { if(ed) {
var raw = ed.getContent().match(/\s(name|id)="([^"]+?)"|\s(name|id)='([^']+?)'/gim); var raw = ed.getContent()
.match(/\s+(name|id)\s*=\s*(["'])([^\2\s>]*?)\2|\s+(name|id)\s*=\s*([^"']+)[\s +>]/gim);
if (raw && raw.length) { if (raw && raw.length) {
for(var i = 0; i < raw.length; i++) { for(var i = 0; i < raw.length; i++) {
var indexStart = (raw[i].indexOf('id=') == -1) ? 7 : 5; var indexStart = (raw[i].indexOf('id=') == -1) ? 7 : 5;

View File

@ -116,6 +116,43 @@ class HtmlEditorFieldTest extends FunctionalTest {
); );
} }
public function testGetAnchors() {
if (!class_exists('Page')) {
$this->markTestSkipped();
}
$html = '<div name="foo"></div>
<div name=\'bar\'></div>
<div id="baz"></div>
<div id=\'bam\'></div>
<div id = "baz"></div>
<div id = ""></div>
<div id="some\'id"></div>
<div id=bar></div>';
$expected = array(
'foo',
'bar',
'baz',
'bam',
"some'id",
'bar',
);
$page = new Page();
$page->Title = 'Test';
$page->Content = $html;
$page->write();
$this->useDraftSite(true);
$controller = new Controller();
$controller->setRequest(new SS_HTTPRequest('GET', '/', array(
'PageID' => $page->ID,
)));
$controller->init();
$toolBar = new HtmlEditorField_Toolbar($controller, 'test');
$this->assertEquals(json_encode($expected), $toolBar->getanchors());
}
public function testHtmlEditorFieldFileLocal() { public function testHtmlEditorFieldFileLocal() {
$file = new HtmlEditorField_File('http://domain.com/folder/my_image.jpg?foo=bar'); $file = new HtmlEditorField_File('http://domain.com/folder/my_image.jpg?foo=bar');
$this->assertEquals('http://domain.com/folder/my_image.jpg?foo=bar', $file->URL); $this->assertEquals('http://domain.com/folder/my_image.jpg?foo=bar', $file->URL);