From: Alexander Ebert Date: Sat, 18 Jul 2020 13:26:50 +0000 (+0200) Subject: Force wsm images to be placed outside of inline elements X-Git-Tag: 5.3.0_Alpha_1~130 X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=6ff9c6f9b19c3833a915fd988b1ee4aefb5818df;p=GitHub%2FWoltLab%2FWCF.git Force wsm images to be placed outside of inline elements Fixes #3410 --- diff --git a/wcfsetup/install/files/lib/system/html/input/node/HtmlInputNodeImg.class.php b/wcfsetup/install/files/lib/system/html/input/node/HtmlInputNodeImg.class.php index 9e8feb8324..898482b39b 100644 --- a/wcfsetup/install/files/lib/system/html/input/node/HtmlInputNodeImg.class.php +++ b/wcfsetup/install/files/lib/system/html/input/node/HtmlInputNodeImg.class.php @@ -3,6 +3,7 @@ namespace wcf\system\html\input\node; use wcf\data\smiley\Smiley; use wcf\data\smiley\SmileyCache; use wcf\system\bbcode\BBCodeHandler; +use wcf\system\bbcode\HtmlBBCodeParser; use wcf\system\html\node\AbstractHtmlNodeProcessor; use wcf\util\DOMUtil; use wcf\util\JSON; @@ -153,6 +154,39 @@ class HtmlInputNodeImg extends AbstractHtmlInputNode { $newElement->setAttribute('data-name', 'wsm'); $newElement->setAttribute('data-attributes', base64_encode(JSON::encode($attributes))); DOMUtil::replaceElement($element, $newElement, false); + + // The media bbcode is a block element that may not be placed inside inline elements. + $parent = $newElement; + $blockLevelParent = null; + $blockElements = HtmlBBCodeParser::getInstance()->getBlockBBCodes(); + while ($parent = $parent->parentNode) { + switch ($parent->nodeName) { + case 'blockquote': + case 'body': + case 'code': + case 'div': + case 'p': + case 'td': + case 'woltlab-quote': + case 'woltlab-spoiler': + $blockLevelParent = $parent; + break 2; + + case 'woltlab-metacode': + if (in_array($parent->getAttribute('data-name'), $blockElements)) { + $blockLevelParent = $parent; + break 2; + } + break; + } + } + + if ($blockLevelParent !== null) { + $element = DOMUtil::splitParentsUntil($newElement, $parent); + if ($element !== $newElement) { + DOMUtil::insertBefore($newElement, $element); + } + } } /**