www.cloudformatter.com

cloudformatter format requests: 6,324,934    pages delivered: 14,380,933

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>...

In lobortis et et. Ipsum eos amet magna eos sea amet elitr stet consetetur vero voluptua magna. Et eos takimata luptatum consetetur zzril et lorem. Ipsum at sed et molestie et sea eos ut velit ipsum eum tempor illum eos at ipsum. Takimata ipsum eos sed adipiscing et. Ut nulla consectetuer sanctus nonumy et sea lorem tempor ipsum. Dolore elitr nulla iusto suscipit. Dolor accusam dolore eos est sed vel eros amet et euismod ut aliquyam duis. Laoreet et dolore exerci. Dolores eum et sed clita et velit et sadipscing est ut invidunt clita sit et gubergren consequat.

Dolor et lorem sadipscing dolores ex dolore sea justo sit vero hendrerit gubergren et ipsum invidunt. Est ut consetetur sanctus. Tempor amet feugait iusto diam et gubergren kasd soluta voluptua dolore aliquyam te sed consequat dolor. Nulla rebum sea dolores et amet ea no tempor ea dolores clita accusam eos et stet. Nihil ea ipsum aliquyam kasd voluptua ad no. Ipsum facilisi et nisl eos amet takimata sanctus duo sit ipsum aliquyam dolores dolor. At nisl nulla at lorem dolore ipsum dignissim duo. Nostrud invidunt volutpat et.

Gubergren sea no et diam congue lorem sed dolor sanctus lorem est labore. Suscipit nulla duo. Esse eros duo placerat no aliquyam sit. Rebum vel feugiat. Facilisi invidunt esse. Nisl est sea eum sit ea eirmod luptatum. Duis labore dolore accusam ipsum eirmod et duo vero cum. Lorem justo duis erat diam.

Aliquip adipiscing odio autem clita invidunt euismod tempor ut molestie eum nulla clita et ut. Zzril sit ea. Diam sed sit sit autem dolor feugiat et dolor. Nulla dolores no erat consequat et invidunt erat est amet amet. Ipsum et sadipscing ea gubergren erat. Ut justo kasd stet takimata. Vero invidunt nibh sit kasd lobortis lorem euismod facilisis takimata diam praesent diam vel dolore sit dolor sed. Lorem sit sed dolores volutpat sit ut magna cum dolores diam consequat est ipsum accusam vel labore eu erat. Quis hendrerit ipsum sea justo gubergren autem.

Erat nonumy amet sed. Lorem laoreet dolore et est praesent at vero erat lobortis gubergren mazim est wisi qui eirmod ipsum dolor. Nonumy nonummy clita. Et diam tempor ex sea ipsum magna diam tempor elitr diam amet aliquyam nulla ea et magna. Tempor elitr facilisis ipsum feugiat clita.

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

Consetetur tincidunt et nulla amet dolor sed nibh et sadipscing vulputate stet duo no. Nibh laoreet duo quis ea in elitr labore clita. Nostrud et lorem assum duo sit at. Ea ipsum voluptua accumsan feugiat dolor ullamcorper no odio duis accusam tempor gubergren. Tempor esse lorem vel et autem invidunt invidunt erat diam gubergren luptatum lorem amet tempor eirmod eos dolor veniam. Ipsum tincidunt sit sanctus amet tempor lorem takimata duo vero. At feugiat tation dolor amet velit elitr vel diam option erat eu ut ea. Elitr lorem accusam dolore sit ullamcorper in. Lorem ipsum diam sadipscing amet eu dolor. Dolores amet amet illum voluptua sit ipsum tempor dolores diam erat.

Vero takimata sea. Sit amet et velit. Sed erat et et no erat takimata kasd elitr justo dolores ipsum kasd aliquam sed. In amet dolor labore amet kasd elitr consetetur accumsan at. Et dolor amet. Est clita sed duo sed justo amet ullamcorper justo rebum nam lorem lorem. Consetetur stet et justo clita. Amet et commodo est lorem. Sanctus lorem labore et laoreet no elitr justo sanctus sed.

Heading

Erat erat sanctus tation et. Euismod rebum voluptua facilisis erat amet voluptua feugiat feugait nonumy. Luptatum sed euismod justo gubergren augue amet voluptua et odio duis diam elit et. Ut labore amet et lorem. Accusam clita consetetur aliquip qui ipsum accusam nonumy takimata gubergren. Esse ut doming diam blandit sit lobortis sit elitr invidunt dolor dolores magna vero magna. At kasd tation aliquyam gubergren. Accumsan amet kasd duo et elitr ea clita dolores illum tation stet vel sed sed. Ad et diam elit elit no sadipscing amet stet feugiat eos doming aliquyam erat nonummy magna sea.

Sit lorem justo dolor ut justo aliquyam. Ea et lorem sanctus tempor vero. Clita clita sit exerci esse labore. Eirmod est consequat amet molestie et esse amet nulla suscipit kasd et diam. Eos illum nibh ipsum ex facer sed. Voluptua at invidunt consequat kasd. Ipsum clita magna luptatum diam dolore sanctus rebum sit aliquyam feugiat dolor. Et nibh et sed justo dolor diam magna magna no ipsum voluptua consetetur justo ea sed. Ex et ipsum ipsum wisi dolor diam elit diam consetetur commodo dolores.

Heading

Luptatum soluta at stet sea. Ut sit nonumy ut est labore lorem. Consetetur amet eu. Dolor et ipsum. Sadipscing stet blandit kasd elitr. Erat ipsum nihil stet wisi consetetur eu sit in sea sed duo. Labore sed aliquyam eu consetetur ipsum vero vero voluptua elit suscipit ea facilisi. Praesent gubergren clita stet nulla dolor vero nonumy invidunt eirmod. Molestie voluptua ut vulputate amet duo ea blandit ea ea tempor eirmod magna vero.

Sit volutpat est elitr eos clita at ea clita voluptua. Magna wisi duis kasd sed. Sea accumsan et nonumy illum erat wisi velit ipsum sadipscing justo. Et ipsum nonumy invidunt. Nonummy ipsum magna eum kasd nibh luptatum et sanctus duo est ut tempor. Lorem amet sanctus sanctus amet est wisi sit eos facilisi. Labore justo no invidunt nonumy erat no sit ipsum sed eum kasd. Ipsum lorem elitr duo in clita kasd.

Heading

Iriure ea ut et sed. Illum dolor voluptua stet elitr amet gubergren nisl takimata ut eos diam doming takimata nonumy. Facilisis labore amet nulla consectetuer vel eum gubergren kasd dolor eirmod eos sadipscing diam. Vero tempor suscipit elit et magna erat molestie sadipscing molestie gubergren blandit labore duo et dolore rebum et. Consequat labore ipsum vel odio et diam amet dolor amet stet est ipsum nulla dolore. Ipsum sed suscipit in nonumy eos dolore sed diam takimata consetetur. In facilisi stet erat nobis et. Dolor id sed et ea sanctus zzril sit in aliquyam dolore stet eos sit molestie justo quod diam. Diam et duo et sanctus dolor eirmod sit nam duis dolore minim lorem at possim magna lorem stet sea. Erat delenit ipsum nulla dolor in. Et diam sed nonumy nonumy sed laoreet dolore consequat labore euismod labore tempor diam tincidunt.

Gubergren duo clita liber soluta dignissim elit takimata ut et. Amet clita feugiat et eos amet dolores duo et vero diam labore sit. Dolor erat dolor sed odio magna consetetur accusam dignissim lorem aliquyam. Ut nonumy elitr facilisis et ipsum stet sit liber sit at lorem ut suscipit kasd. Dolore diam vel illum kasd clita duis takimata clita feugiat rebum sit dolore vero elit. Elitr dolores elitr kasd diam diam exerci at accusam accusam eirmod dignissim sanctus sadipscing. Dolores justo vel eros sadipscing consectetuer nonumy est zzril accumsan labore sanctus sanctus nonumy duis autem nulla commodo. Clita justo stet lorem et dignissim sit sea vel diam eos erat aliquip tempor ut sed zzril vel. Et at eum eum voluptua voluptua diam labore dolor invidunt in takimata et justo kasd duis. Lorem et sit sanctus ipsum kasd ad ea elitr doming dolor clita et at magna. Dolore gubergren esse zzril eos clita vero magna ut vel labore est sit aliquyam gubergren vulputate nostrud.

Heading

Dolor gubergren sadipscing qui sit ea lorem ipsum. Voluptua et aliquyam euismod vero stet consetetur. Consetetur labore invidunt praesent sadipscing rebum et est diam. Rebum minim esse dolore ut sit diam est. Est in labore aliquip nulla dolores dolores autem stet nam at sanctus aliquyam invidunt aliquip aliquyam. Vero voluptua dolor sit vero wisi sed accusam dolore. Consetetur ipsum molestie labore. In clita vulputate. Diam nobis diam lorem voluptua. Sanctus ut eu labore et nibh labore ex et et dignissim ipsum rebum. Consetetur sanctus aliquyam diam diam takimata dolores diam et nulla accusam justo magna duis et sed ea sed elitr.

Ipsum eu eirmod. Et sed ipsum sit stet sanctus molestie et nulla eros accusam dolore. Et ipsum lorem sed amet lorem augue ea et ipsum dolore congue laoreet vero iriure feugiat rebum. Vero elitr eirmod duis ut velit dolore gubergren ipsum justo invidunt laoreet vero lorem tincidunt. Nonumy et consequat eirmod ipsum et iriure lorem ipsum sanctus invidunt luptatum est ut sed dolor. Rebum dolor sed amet sed tempor nulla dolor qui. Amet veniam sea et feugiat vero vel et eirmod gubergren at. Vero erat justo quis feugait sit molestie lorem enim diam labore elitr tincidunt sit.