ZhgChgLi/ZMarkupParser

Add better table rendering support

charrondev opened this issue · 3 comments

I've noticed that table rendering is relatively lackluster.

I'm willing to take a crack at it in the next few months but wanted to open this issue to start getting some ideas down.

Current Limitations

Currently the table implementation creates tries to even things out by making use of whitespace characters to even the columns. This has numerous shortcomings, most notably that

  • It requires the use of a monospaced font to even partially work.
  • It doesn't allow having column or row separators
  • Lines wrap breaking the flow.

Implementation Ideas

My goal would be something like the following:

  • Tables get rendered to exactly the with or their parent container.
    • The can be scrolled horizontally if they are longer than expected.
  • Tables cells can wrap their contents
  • Table cells will have a configurable fixed width
  • The underlying table will have a few styling options:
    • Control column/row separators
    • Allow alternating row colors

To actually accomplish this it will certainly need to be some type of NSTextAttachment, and ZNSTextAttachment seems like a good enough inspiration of something with dynamic, initially unknown height to calculate and render.

The issue of handling tables is indeed quite complex because NSAttributedString only provides basic typesetting functionality.

Achieving a complete table implementation, including scaling, can be very challenging.

Currently, the project only has a simple implementation for tables.

One possible approach could be obtaining the screen size and converting the table content into an image to be inserted into NSAttributedString.

ref: may use ascii-table instead: https://ozh.github.io/ascii-tables/

I've abandonded my use of Swift altogether for the area that I need to view HTML content and am instead just using a webview.

In addition to having much greater support for all manor of HTML, I'm also finding it's rendering on large amounts of text far faster than the equivalent NSAttributedStrings. I wasn't expecting that at all.