www.cloudformatter.com

cloudformatter format requests: 6,307,782    pages delivered: 14,351,846

Pass-Through XSL FO Styling

xportability LLC

Pass-Through XSL FO Styling

http://www.cloudformatter.com

Note:

We implemented the spacialized attribute fostyle to carry this information. Because the browser just ignores this, you must be careful to structure it correctly for processing. The proper structure is name: value; noting that the ":" after name is followed by a space and the ";" between items is also followed by a space.

In some instances you may wish to pass through XSL FO attributes that are not supported in HTML. This is an example, while the text in the HTML has a brown color applied, we have applied a CMYK color for the PDF generation through the use of the fostyle attribute. All fostyle attributes are applied after HTML css and also after direct attributes and override those in the HTML. This paragraph also has text-align justify in the HTML and font-stretch, font-size-adjust and hyphenate in the PDF output. The fostyle attribute is attached right in the HTML, just like style and uses the same structure internally as style.

The code for the paragraph above looks like this:

<p style="color: brown; text-align:justify;"
    fostyle="text-align-last: left; 
    font-stretch: wider; 
    font-size-adjust: 0.6; 
    hyphenate: true; 
    color: rgb-icc (255, 255, 0, #CMYK, .1, .2, .7, .5);">In some instances ...

Keeps of Various Kinds

Another common use for passing through custom elements is for properties that have specific meaning in a pagination situation like "keeps". There are several forms of keeps that can help you organize content so it is glued together as you like it.

The following are the most commonly used keeps:

  • keep-together.within-page: set to "always" and used to keep a block of content always together in a single page
  • keep-with-next.within-page: set to "always" and used to keep a block of content glued to the next one always together in a single page
  • keep-with-previous.within-page: set to "always" and used to keep a block of content glued to the previous one always together in a single page
  • keep-together.within-line: set to "always" and used to keep a span of content glued always together in a single line

The following shows some demonstrations of these capabilities.

Keeping Together Within a Page

This paragraph, the instructions and the following three para's of LoremIpsum text are surrounded by a <div> with keep-together.within-page as always, like this:

<div fostyle="keep-together.within-page: always;">
    <p>This paragraph, the instructions and the following five para's of LoremIpsum text are surrounded 
    by a <div> with "keep-together.within-page" as "always", like this:</p>...

Ipsum eirmod ipsum suscipit eros et soluta. Dolor hendrerit voluptua nonumy dolor euismod eros sanctus. Et rebum nulla et diam vero nonumy duo autem ea nonumy. Magna sed accusam magna diam ea nonumy eirmod autem eros elitr eu elit sanctus ea. Est quis erat diam et illum sea invidunt diam molestie at ipsum rebum. Sed est stet et amet lorem lorem no takimata sed dolore sit eros et stet at dolores velit gubergren.

Labore ut invidunt rebum diam et consequat ipsum labore facer at vero dolore autem eirmod diam dolor. Dolor clita stet iusto. Ea eleifend dignissim vel lorem dolor. Eos eirmod sed eos sadipscing justo vero ipsum kasd sed enim nonumy aliquip adipiscing eum nulla. Adipiscing vel nisl et adipiscing quod facilisis sit dolor rebum accusam stet ipsum et tempor dolor duo duo ut. Tempor lorem ex dolore ea duis iusto rebum takimata dolor et. Vero ipsum et esse ad lorem takimata nibh kasd eos feugiat est nam invidunt no takimata sit. Ipsum sit diam at erat in erat gubergren dolor et invidunt sit.

Sadipscing dolores dolore autem lorem accusam vero ea clita voluptua ipsum rebum vero autem nonumy at tempor. Dolores nonumy sit lorem rebum ipsum quis. Nisl cum ipsum dolores sea eu delenit tempor clita ipsum dolore sed duo eum. Accusam diam rebum lorem ea qui ea et voluptua dolor et et eirmod iriure eirmod dolor. Eirmod duo zzril dolor stet te duo consetetur duo in consectetuer. Sed voluptua amet eos voluptua stet dolore amet sed sit molestie dolor. Voluptua duis molestie imperdiet hendrerit no et. Sea sed ea dolor quis no elit amet gubergren feugiat amet consequat et lorem no ipsum gubergren eum consectetuer. Assum autem voluptua feugiat elitr takimata invidunt gubergren ea. Ut sed voluptua dolores justo justo molestie erat.

Lorem eirmod duo zzril accusam consetetur sadipscing. No dolore consequat aliquyam amet tempor illum feugiat rebum ut dolore soluta diam qui option amet nonumy odio magna. Minim nonumy diam feugiat. Gubergren aliquam duo. Aliquyam sed dolor consectetuer gubergren magna eirmod. Imperdiet labore nonumy invidunt et tincidunt amet laoreet dolore eu ut magna placerat nibh duis iriure in aliquyam. Voluptua et dolores illum consequat dolor sed ut diam takimata et erat amet amet lorem veniam odio diam duo.

Nonumy diam magna clita dolores. Eirmod dolor at est amet rebum ex tation voluptua. Volutpat eirmod nonumy diam accusam gubergren sit clita ex ipsum takimata tempor ea. Kasd magna eos lorem invidunt magna et eos dignissim magna autem enim clita nisl at et praesent in nonumy. Est eum aliquyam aliquyam id congue nisl qui nonummy feugiat eirmod consetetur magna adipiscing sadipscing mazim no.

Thus all of this content from the header through this paragraph is together on a single page.

Keep Heading with Para and Table

A common practice in print documents is keeping together headings and some of the following lines of a paragraph so no heading is orphaned at bottom of a page and at least a few lines of text from any paragraph stay together.

What follows this are a series of headings and LoremIpsum paragraphs. The headings all have "keep-with-next.within-page" as "always" which will at least glue them to the paragraph. The paragraphs all have widows of "3" and orphans of "3" which will attempt to glue together at least three lines of paragraph at the bottom and top of any page. The LoremIpsum paragraphs are randomly generated on refresh of the page so you can test various layouts just by refresing and printing again.

Heading

Erat gubergren amet consequat diam eleifend at ipsum. Invidunt vulputate invidunt veniam. Et eos dolore sed quod at vero no consequat amet eirmod eos eleifend sed amet. Dolor sed est takimata tincidunt eos gubergren takimata at ipsum vel. Accumsan blandit sed kasd placerat dolore sanctus vero ut dolor ea blandit ipsum tempor diam lorem. Sanctus lorem labore ipsum sanctus blandit iriure option nulla. Gubergren rebum eu zzril erat no eos duo et est. In at ut wisi labore amet voluptua ipsum tincidunt dolor nulla gubergren consetetur justo lorem amet. Diam ea rebum magna et aliquyam amet clita dolore liber liber no at dolor.

Accusam lorem at lorem lorem iusto vulputate qui rebum aliquyam lorem magna lorem ut. Aliquyam no eros dolore duo gubergren. Takimata iriure diam. Dignissim euismod hendrerit ut diam. Lorem nobis sanctus assum diam sit sed delenit. Consetetur et ipsum diam rebum feugait sit no dolore sit autem aliquip sadipscing. Dolor iriure stet gubergren dolore. Sea magna sanctus duis et iriure dolore eu sed dolore elitr elit sit lorem zzril vel ipsum qui at. Accumsan labore ea diam aliquam ut sea sed duo dolor kasd diam quis augue esse delenit kasd.

Heading

Diam eos ipsum ipsum lorem diam ea eirmod. Stet feugait ipsum in consequat invidunt amet eos amet ea diam ipsum duo. Amet kasd erat sit et. Sit dolores invidunt aliquyam sadipscing accusam nonumy nonumy. Ea magna iusto magna nonumy amet accumsan sed invidunt nonumy nulla dolore nulla. Rebum qui dolor justo duo sed voluptua et sea sit amet eirmod lorem. Facilisi nobis rebum magna takimata euismod. Ut duo volutpat eu clita possim et duis stet te.

Nisl in facilisis facilisis sit velit ad diam facilisis et voluptua kasd. Sed dolores odio wisi invidunt magna sed nonumy. Aliquyam sit aliquyam nostrud sanctus. Nostrud eros lorem lorem dolor. Amet sit diam eirmod stet eros. Sit est ea voluptua ut in et molestie. Consetetur iusto rebum sea magna ut kasd sed lorem kasd sed aliquyam ex lorem lorem in invidunt. Sed molestie in amet. Esse labore aliquam elitr ea voluptua augue feugiat lobortis rebum rebum diam nibh diam iusto odio.

Heading

Duis nonumy consequat sadipscing kasd ut dolor kasd ut ea no aliquyam labore invidunt amet. Eros tempor nibh at quis ipsum lorem facilisis sed luptatum. Accusam dolor ex ipsum erat kasd sadipscing consetetur est at te kasd esse diam lorem diam commodo. At voluptua diam eu sit. Qui amet ipsum dolore feugiat cum sed luptatum amet ipsum nulla autem lorem consectetuer imperdiet. Amet elitr consetetur est et te eirmod molestie consetetur. Sanctus et lorem nonumy no nulla amet ut sed tempor sadipscing consequat dolore accusam dolores consetetur kasd ipsum erat. Qui clita amet tincidunt eu tempor in elitr et at. Rebum dolor blandit duis dolor vel diam vulputate eirmod et justo et sadipscing gubergren stet gubergren takimata. Et stet labore diam esse tempor.

Nihil sea iusto nonumy sea ipsum ipsum dolor eu et rebum suscipit et. Voluptua rebum in nonumy dolor nonumy dolor rebum diam id diam nonumy sed. Et sanctus ad et ex sanctus amet lorem dolor enim no dolores. Dolor magna magna. Labore et dolore tempor lorem invidunt dolore hendrerit lorem sit labore ipsum erat mazim clita vero. At eos justo exerci sanctus sed kasd diam clita eos magna. Et velit gubergren ut lorem nihil dolor laoreet amet amet aliquam erat consectetuer. At adipiscing erat vero voluptua et voluptua commodo eirmod sea kasd. Erat elitr elitr no dolor rebum nisl. Labore nisl dolores delenit delenit consetetur duo stet sit sanctus laoreet diam at. Ea luptatum dolore aliquam diam sed elitr dolor vel sea stet.

Heading

Takimata magna ex aliquyam est amet diam magna accusam praesent duis consetetur. Ipsum sanctus dolor zzril est accusam eum iusto nulla at ut duo sit clita sit vero et. Aliquip et quod in takimata hendrerit diam dolores. Invidunt consetetur dolor lorem duo rebum option amet invidunt nonumy. Lorem elitr amet dolor. Aliquyam diam kasd est eirmod et assum lorem diam ipsum. Nam clita ipsum consetetur laoreet eirmod et gubergren stet erat voluptua nulla tincidunt sit sadipscing.

Ut et nulla sea duis diam sit rebum amet clita magna rebum ipsum ipsum. Et diam elitr vulputate eirmod amet dolore amet dolore labore ut accusam ad tempor invidunt lorem nonumy consetetur. Ea dolores facilisi clita gubergren vel dolor sed molestie elitr amet dolor lobortis magna praesent esse. Sea ex euismod sanctus consequat velit vero voluptua consetetur sanctus. Amet stet sea at et nostrud dolore sea magna sed et sanctus sed sit. Nulla diam eirmod amet diam clita duis accusam nonumy. Amet dolor erat imperdiet dolores aliquip commodo facilisis accumsan labore eos et justo diam lorem. No elitr tempor eros autem illum at voluptua magna gubergren diam dolore et.

Heading

Veniam autem accusam duo nam tempor aliquyam dolor sadipscing. Sed duo amet molestie nostrud et kasd diam sanctus dolor nibh. Soluta vulputate ipsum at dolor ut. Amet ipsum stet rebum ullamcorper magna cum ipsum no te clita augue kasd sit amet eos dolores dolor eos. Amet consetetur consectetuer gubergren nulla et te sit ea et. Ea delenit erat elitr magna dolor est consetetur vero sanctus eos dolores accusam. Diam ea possim elitr dolor aliquip kasd nihil voluptua takimata eos nobis lorem hendrerit invidunt erat exerci duo. Erat amet lorem et ipsum rebum voluptua clita.

Dolore eirmod elitr. Et cum esse est esse magna dolore magna est esse. Et veniam consetetur amet nibh amet dolores nonumy hendrerit elitr lorem diam et clita sed. Elitr nulla congue kasd qui aliquyam tempor tempor invidunt vel ut vel eirmod magna ut diam. Kasd dolore duo luptatum erat voluptua erat dolores et ea erat dolores stet tincidunt duo. Sanctus nonumy consetetur tincidunt amet ipsum laoreet ut eos eum sed accusam. Amet amet ut no diam accusam eirmod gubergren. Sit eleifend dolor gubergren suscipit amet duo et dolor vero vel. Dolore sed eu sit amet consetetur lorem laoreet diam sit dolor diam lobortis adipiscing.