Scryber 5.0

What if there was a better way to create documents, is at the heart of everything we do.

Scryber is the engine to create dynamic PDF documents quickly and easily from HTML templates with consistant styles, your own data, and an easy flowing layout. It’s open source; flexible; styles based; data driven and with a low learning curve.

Written entirely in C# for dotnet 5 using HTML, CSS and SVG.

Documentation for previous 1.0.x pdfx versions for Read the docs here

Hello World MVC

Download the nuget package

https://www.nuget.org/packages/Scryber.Core.Mvc

Start with a template. The namespace declaration is important.

<!DOCTYPE HTML >
<html lang='en' xmlns='http://www.w3.org/1999/xhtml' >
    <head>
        <title>{@:model}</title>
    </head>
    <body>
        <div style='padding:10px'>{@:model}.</div>
    </body>
</html>

And then generate your template in a view.

//add the namespaces
//using Scryber.Components;
//using Scryber.Components.Mvc;
//using Microsoft.AspNetCore.Mvc;

public class HomeController : Controller
{

    private readonly IWebHostEnvironment _env;

    public HomeController(IWebHostEnvironment environment)
    {
        _env = environment;
    }

    [HttpGet]
    public IActionResult HelloWorld()
    {
        // get the path to where you have saved your template
        var path = _env.ContentRootPath;
        path = System.IO.Path.Combine(path, "Views", "PDF", "HelloWorld.html");

        //parsing the document creates a complete object graph from the content
        using(var doc = Document.ParseDocument(path))
        {
            doc.Params["model"] = "Hello World";
            return this.PDF(doc); //convenience extension method to return the result.
        }
    }

}

Try it out here…

_images/HelloWorldIndex.png

Hello World Plus

Check out MVC Controller - Getting Started for a full MVC example with styles and binding, or Console or GUI - Getting Started for a full gui application example (with styles and binding)

Features

Easy, and intuitive structure

Whether you are using xhtml templates or directly in code, scryber is quick and easy to build complex documents from your designs and data using standard xhtml.

File structure

Intelligent flowing layout engine

In scryber, content can either be laid out explicitly, or jut flowing with the the page. Change the page size, or insert content and everything will adjust around it.

Pages and Sections

Cascading Styles

With a styles based structure, it’s easy to apply designs to templates. Use class names, id’s or component types, or nested selectors.

Styles in your template

Drawing and Typographic support

Scryber supports inclusion of Images, Fonts (inc. Google fonts) and SVG components for drawing graphics and icons.

Document fonts and text styles, Images in documents and Drawing with SVG

Standard HTML tags

Use divs, spans, tables, lists, headers, footers, links, images and many other standard tags to support your document building or page conversion.

Standard document components, Links in and out of documents or Images in documents

Binding to your data

With a simple binding notation it’s easy to add references to your data structures and pass information and complex data to your document from SQL, JSON, Entity Model and more. Or get the document to look up and bind the data for you.

Dynamic content in your template

Extensible Framework

Scryber was designed from the ground up to be extensible. If it doesn’t do what you need, then we think you can make it do it. With iFrame includes, a namespace based parser engine, and configuration options for images, fonts, binding it’s down to your imagination

Secure and Encrypted

Scryber fully supports the PDF restrictions and both 40 bit and 128 bit encryption of documents using owner and user passwords.

Securing Documents