On Tue, Mar 28, 2017 at 12:13 AM, ktc <[email protected]> wrote:

> EDITED: Resending this message to fix some escaping issues when the email
> went out the first time.
>
> I have a use case where I need to nest macros to 2+ levels deep using
> XWiki's Annotated XHTML syntax. We are using this syntax as an input to a
> transformation process that utilizes XWiki's rendering engine to convert
> the
> Annotated XHTML into XWiki-native markup, similarly to how CKEditor does
> its
> work.
>
> The problem is that with Annotated XHTML, macros are encoded as HTML
> comments -- but HTML comments cannot be nested within other HTML comments.
>
> Here is a demonstrative example: (NOTE: in all examples below I have added
> extra spaces around the ! chars to prevent these from getting stripped out
> in this email)
>
>   < ! --startmacro:outermacro|-||-|outer text before < !
> --startmacro:innermacro|-||-|inner text-->< ! --stopmacro--> outer text
> after-->< ! --stopmacro-->
>
> The intention is for this to be convertible to this XWiki syntax:
>
>   {{outermacro}}outer text before {{innermacro}}inner text{{/innermacro}}
> outer text after{{/outermacro}}
>
> However, this doesn't work because the HTML parser sees the first "-->" it
> encounters as the "end of comment" marker, thus breaking the intended
> nesting.
>
> Thus, when converted to XWiki syntax, this is what comes out instead:
>
>   {{outermacro}}outer text before <==startmacro:innermacro|-||-|inner
> text{{/outermacro}} outer text after ~-~->
>
>
> We have considered a couple possible solutions:
>
> 1. Mimic what CKEditor does in this scenario, which is to use an HTML
> comment for the outermost macro-block, but have any nested macros (embedded
> inside the HTML comment) be rendered as XWiki-native syntax. Like this:
>
>   < ! --startmacro:outermacro|-||-|outer text before {{innermacro}}inner
> text{{//innermacro}} outer text after-->< ! --stopmacro-->
>
> This approach seems to work, but it's not ideal because our Annotated XHTML
> generation code will now need to support two varieties of output depending
> on the current nesting level -- Annotated XHTML for the outermost depth,
> and
> XWiki-native for anything nested deeper.
>
>

> 2. Implement a variation of the existing Annotated XHTML parsing logic
> which, instead of expecting macros encoded in HTML comments, will expect
> the
> use of an XHTML structure that models the same information, but doesn't
> suffer from the nesting restrictions of HTML comments. Something like this:
>

A note on this: using XML comments for macro markers (solution 1) has
proven to be fragile for the CKEditor integration because the HTML produced
by rendering macros (especially by those that are not maintained by the
XWiki Development team) is often not valid which creates problems when the
browser attempts to fix the HTML. The start/stop macro comments must be on
the same level and the browser often moves these comments when the HTML is
not valid. See https://jira.xwiki.org/browse/CKEDITOR-131 .

I think it's interesting to investigate using elements or attributes
instead of comments for macro markers (solution 2). Although it doesn't
prevent macros from generating invalid HTML, it may be more robust against
mutations performed by the browser when fixing the HTML.

Thanks,
Marius


>
>   <xannotation name="startmacro:outermacro">
>     outer text before
>     <xannotation name="innermacro">
>       inner text
>     </xannotation>
>     outer text after
>   </xannotation>
>
>
> I am looking for input from XWiki experts regarding what approach would
> make
> the most sense. Option 2 above seems like the most elegant solution
> overall,
> but I'm not sure how difficult this would be to get working in the current
> XWiki codebase, or what file(s) would need to be extended, etc. Is there
> another approach that might solve this problem more efficiently?
>
>
> Note: For brevity, I've referred to "nested macros" above, but for our use
> case we will actually need to handle all the different comment types
> recognized in XWikiCommentHandler.java.
>
>
> References:
> AnnotatedXHTMLRenderer.java:
> https://github.com/xwiki/xwiki-rendering/blob/master/
> xwiki-rendering-syntaxes/xwiki-rendering-syntax-
> annotatedxhtml/src/main/java/org/xwiki/rendering/internal/renderer/xhtml/
> AnnotatedXHTMLRenderer.java
> XWikiCommentHandler.java:
> https://github.com/xwiki/xwiki-rendering/blob/master/
> xwiki-rendering-syntaxes/xwiki-rendering-syntax-xhtml/
> src/main/java/org/xwiki/rendering/internal/parser/xhtml/wikimodel/
> XWikiCommentHandler.java#L90-L99
>
>
>
> --
> View this message in context: http://xwiki.475771.n2.nabble.
> com/RESEND-Nesting-within-Annotated-XHTML-tp7603271.html
> Sent from the XWiki- Dev mailing list archive at Nabble.com.
>

Reply via email to