v25.1 change in behavior for <image placement="break">
Having trouble installing Oxygen XML WebHelp? Got a bug to report? Post it all here.
			- 
				chrispitude
- Posts: 922
- Joined: Thu May 02, 2019 2:32 pm
v25.1 change in behavior for <image placement="break">
Post by chrispitude »
This is a heads-up to my fellow WebHelp users. Given a DITA <image> element with @placement="break":
In v25.0, the webhelp-responsive transformation produces HTML that uses a @class="break" property to apply "display: block" via CSS:
In v25.1, the webhelp-responsive transformation produces HTML that uses <br> elements to make the images effectively block elements:
The v25.1 webhelp-responsive behavior matches the DITA-OT's html5 transformation behavior, which has always used <br> elements to bound placement="break" images (including in Oxygen v25.0).
However, the default CSS properties for <br> elements cause additional vertical space to be added above the image. I'm still deciding how I want to fix this in our flow:
Here's a small testcase for experimentation:
			
			
						Code: Select all
<p>LINE</p>
<image href="image.png" placement="break"/>
<p>LINE</p>Code: Select all
<p class="- topic/p p">LINE</p>
<img class="- topic/image image break" src="image.png"/>
<p class="- topic/p p">LINE</p>Code: Select all
<p class="- topic/p p">LINE</p>
<br><img class="- topic/image image" src="image.png"/><br>
<p class="- topic/p p">LINE</p>However, the default CSS properties for <br> elements cause additional vertical space to be added above the image. I'm still deciding how I want to fix this in our flow:
- Keep the <br> elements, but add a line-height: 0 property in our CSS file
- In our HTML5 DITA-OT plugin, remove the <br> elements and reapply @class="break" to these image elements
- In our HTML5 DITA-OT plugin, remove the <br> elements and add @styles="display: block" to these image elements
Here's a small testcase for experimentation:
webhelp-images-placement-break.zip
You do not have the required permissions to view the files attached to this post.
							
					Last edited by chrispitude on Fri May 26, 2023 3:06 pm, edited 1 time in total.
									
			
									
						- 
				chrispitude
- Posts: 922
- Joined: Thu May 02, 2019 2:32 pm
Re: v25.1 change in behavior for <image placement="break">
Post by chrispitude »
Well this is frustrating! If the output is serialized as XHTML, then the <br> element considers the line-height CSS property:
But if the output is serialized as HTML5 (the default), then the <br> element ignores line-height completely:
I was going to propose an enhancement to the DITA-OT's default CSS to apply line-height: 0 to <br> elements, but without resolving this issue, it would be ignored.
display: none does not work, because then consecutive @placement="break" images would get stacked on the same line as inline images.
			
			
									
									
						Code: Select all
<?xml version="1.0" encoding="UTF-8"?>
<html lang="en">
 <head>
  <style>br {line-height: 0}</style>
 </head>
 <body>
  <p>LINE</p>
  <br /><span>image</span><br />
  <p>LINE</p>
 </body>
</html>Code: Select all
<!DOCTYPE html>
<html lang="en">
 <head>
  <style>br {line-height: 0}</style>
 </head>
 <body>
  <p>LINE</p>
  <br><span>image</span><br>
  <p>LINE</p>
 </body>
</html>display: none does not work, because then consecutive @placement="break" images would get stacked on the same line as inline images.
- 
				chrispitude
- Posts: 922
- Joined: Thu May 02, 2019 2:32 pm
Re: v25.1 change in behavior for <image placement="break">
Post by chrispitude »
I filed the following DITA-OT issue:
#4202: Images with @placement="break" have extra blank space above them in HTML5 output
			
			
									
									
						#4202: Images with @placement="break" have extra blank space above them in HTML5 output
- 
				chrispitude
- Posts: 922
- Joined: Thu May 02, 2019 2:32 pm
Re: v25.1 change in behavior for <image placement="break">
Post by chrispitude »
So now I see the reason for the difference in WebHelp behavior. There is an "html5-images.xsl" stylesheet in the WebHelp and PDF Chemistry transformations that converts the adjacent <br> elements to @class="break" added to the image. This stylesheet is used in both versions of PDF Chemistry, but only in v25.0 of WebHelp:
As a workaround, I will include this stylesheet in our company's WebHelp plugin using the com.oxygenxml.webhelp.xsl.dita2webhelp extension point. The "break" keyword is added twice in v25.0 because both copies of html5-images.xsl add it. I tried to work around this by not copying the keyword if it already exists in our copy:
but unfortunately in
			
			
									
									
						Code: Select all
$ find . -name 'html5-images.xsl'
./oxygen-publishing-engine-3.x-25.0-2023012609/plugins/com.oxygenxml.pdf.css/xsl/merged2html5/html5-pdf-webhelp/html5-images.xsl
./oxygen-publishing-engine-3.x-25.0-2023012609/plugins/com.oxygenxml.webhelp.responsive/xsl/dita2webhelp/html5-pdf-webhelp/html5-images.xsl
./oxygen-publishing-engine-25.1-2023042507/plugins/com.oxygenxml.pdf.css/xsl/merged2html5/html5-pdf/html5-images.xslCode: Select all
      <xsl:when test="$placement = 'break' and not(tokenize(., '\s+') = 'break')">
        <xsl:attribute name="class" select="concat(., ' ', $placement)"/>
      </xsl:when>the Oxygen XSLT files are applied after the com.oxygenxml.webhelp.xsl.dita2webhelp extension point, which means a user plugin cannot override WebHelp templates. I will file an enhancement request to move the extension point to be last.plugins/com.oxygenxml.webhelp.responsive/xsl/dita2webhelp/dita2webhelp_template.xsl
- 
				radu_pisoi
- Posts: 404
- Joined: Thu Aug 21, 2003 11:36 am
- Location: Craiova
- Contact:
Re: v25.1 change in behavior for <image placement="break">
Post by radu_pisoi »
Hi,
I have tested the com.oxygenxml.webhelp.xsl.dita2webhelp extension point with WebHelp 25.1 using a publishing template. After running the DITA-OT Integrator, the XSLT file associated with the extension points is imported after the WebHelp XSLT stylesheet.
The template:xsl/com.oxygenxml.webhelp.xsl.dita2webhelp XSLT stylesheet is resolved through the XML catalog to the custom user XSLT stylesheet.
Do you reproduce this with 25.1 version? You can upgrade freely from version 25.0 to 25.1.
			
			
									
									I have tested the com.oxygenxml.webhelp.xsl.dita2webhelp extension point with WebHelp 25.1 using a publishing template. After running the DITA-OT Integrator, the XSLT file associated with the extension points is imported after the WebHelp XSLT stylesheet.
Code: Select all
<xsl:import href="dita2webhelpImpl.xsl"/>
<xsl:import xmlns:dita="http://dita-ot.sourceforge.net" href="template:xsl/com.oxygenxml.webhelp.xsl.dita2webhelp"/>
Do you reproduce this with 25.1 version? You can upgrade freely from version 25.0 to 25.1.
Radu Pisoi
<oXygen/> XML Editor, Schema Editor and XSLT Editor/Debugger
http://www.oxygenxml.com
						<oXygen/> XML Editor, Schema Editor and XSLT Editor/Debugger
http://www.oxygenxml.com
- 
				chrispitude
- Posts: 922
- Joined: Thu May 02, 2019 2:32 pm
Re: v25.1 change in behavior for <image placement="break">
Post by chrispitude »
Hi Radu,
Indeed you are correct! I misunderstood how the extension points were structured in the template file. Instead, there was a bug in my workaround plugin that caused the duplicate values in v25.0.
If anyone wants to revert to the CSS-based @class~="break" behavior, you can use this workaround plugin:
This works in both v25.0 (does not affect output) and v25.1 (converts the <br> structure to @class~="break").
Radu, was this change made to align WebHelp's output to the default DITA-OT HTML5 output? I like that the outputs are more aligned, but maybe we can work together to fix DITA-OT issue #4202. The cleanest solution actually seems to be how WebHelp implemented it in v25.0 - would you be interested in seeing the DITA-OT adopt this approach natively?
			
			
						Indeed you are correct! I misunderstood how the extension points were structured in the template file. Instead, there was a bug in my workaround plugin that caused the duplicate values in v25.0.
If anyone wants to revert to the CSS-based @class~="break" behavior, you can use this workaround plugin:
com.synopsys.webhelp-images-placement-break.zip
This works in both v25.0 (does not affect output) and v25.1 (converts the <br> structure to @class~="break").
Radu, was this change made to align WebHelp's output to the default DITA-OT HTML5 output? I like that the outputs are more aligned, but maybe we can work together to fix DITA-OT issue #4202. The cleanest solution actually seems to be how WebHelp implemented it in v25.0 - would you be interested in seeing the DITA-OT adopt this approach natively?
You do not have the required permissions to view the files attached to this post.
			
									
						
			
				Jump to
				
			
		
			
			
	
	- Oxygen XML Editor/Author/Developer
- ↳ Feature Request
- ↳ Common Problems
- ↳ DITA (Editing and Publishing DITA Content)
- ↳ Artificial Intelligence (AI Positron Assistant add-on)
- ↳ SDK-API, Frameworks - Document Types
- ↳ DocBook
- ↳ TEI
- ↳ XHTML
- ↳ Other Issues
- Oxygen XML Web Author
- ↳ Feature Request
- ↳ Common Problems
- Oxygen Content Fusion
- ↳ Feature Request
- ↳ Common Problems
- Oxygen JSON Editor
- ↳ Feature Request
- ↳ Common Problems
- Oxygen PDF Chemistry
- ↳ Feature Request
- ↳ Common Problems
- Oxygen Feedback
- ↳ Feature Request
- ↳ Common Problems
- Oxygen XML WebHelp
- ↳ Feature Request
- ↳ Common Problems
- XML
- ↳ General XML Questions
- ↳ XSLT and FOP
- ↳ XML Schemas
- ↳ XQuery
- NVDL
- ↳ General NVDL Issues
- ↳ oNVDL Related Issues
- XML Services Market
- ↳ Offer a Service