QuestPDF 2022.1.0-beta5

Prefix Reserved
This is a prerelease version of QuestPDF.
There is a newer version of this package available.
See the version list below for details.
dotnet add package QuestPDF --version 2022.1.0-beta5
                    
NuGet\Install-Package QuestPDF -Version 2022.1.0-beta5
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="QuestPDF" Version="2022.1.0-beta5" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="QuestPDF" Version="2022.1.0-beta5" />
                    
Directory.Packages.props
<PackageReference Include="QuestPDF" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add QuestPDF --version 2022.1.0-beta5
                    
#r "nuget: QuestPDF, 2022.1.0-beta5"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package QuestPDF@2022.1.0-beta5
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=QuestPDF&version=2022.1.0-beta5&prerelease
                    
Install as a Cake Addin
#tool nuget:?package=QuestPDF&version=2022.1.0-beta5&prerelease
                    
Install as a Cake Tool

QuestPDF Overview

QuestPDF is an open-source, modern and battle-tested library that can help you with generating PDF documents by offering friendly, discoverable and predictable C# fluent API.

Features

Rely on solid fundamentals - This library is created specifically for designing and arranging document layouts, with full paging support. Alternative solutions, such as HTML-based converters, are not designed for this purpose and therefore are often unpredictable and do not produce desired results.

Work with organized self-explanatory code - The entire process of implementing PDF document, takes place in your code. Free yourself from slow visual designers and strange technological limitations. Follow simple yet highly effective approaches to create maintainable, high-quality code.

Compose simple components into complex documents - Do you remember the feeling when your code just works? When your ideas are becoming real without any effort? Working with simple, easy to understand, self-explanatory and highly composable layout elements is the key here!

Create and reuse components - Feel no fear of complex documents! Create custom, reusable components and divide the document's layout into easy to maintain pieces. Inject data to customize content and use slots to enhance composability. Decide how complex approaches your solution needs and follow the best path.

Prototype with ease - We understand that document generation is often tricky and require multiple iterations. The library offers additional prototyping tools such as random text generator or image placeholder element. By following best practices, you can develop a document without having data.

Enjoy fast PDF generation - QuestPDF is created upon SkiaSharp, a well-known graphical library, and converts your data into PDF documents. It offers a highly optimized layouting engine capable of generating over 1000 PDF files per minute per core. The entire process is thread-safe.

Learning resources

Release notes and roadmap - everything that is planned for future library iterations, description of new features and information about potential breaking changes.

Getting started tutorial - a short and easy to follow tutorial showing how to design an invoice document under 200 lines of code.

API Reference - a detailed description of behavior of all available components and how to use them with C# Fluent API.

Patterns and practices - everything that may help you designing great reports and reusable code that is easy to maintain.

Example invoice

Do you believe that creating a complete invoice document can take less than 200 lines of code? We have prepared for you a step-by-step instruction that shows every detail of this implementation and describes the best patterns and practices.

For tutorial, documentation and API reference, please visit the QuestPDF documentation.

invoice

Here you can find an example code showing how easy is to write and understand the fluent API.

General document structure with header, content and footer:

public void Compose(IDocumentContainer container)
{
    container
        .Page(page =>
        {
            page.Margin(50);
            
            page.Header().Element(ComposeHeader);
            page.Content().Element(ComposeContent);
            
            page.Footer().AlignCenter().Text(x =>
            {
                x.CurrentPageNumber();
                x.Span(" / ");
                x.TotalPages();
            });
        });
}

The header area consists of basic invoice information along with a logo placeholder.

void ComposeHeader(IContainer container)
{
    var titleTextStyle = TextStyle.Default.Size(20).SemiBold().Color(Colors.Blue.Medium);
    
    container.Row(row =>
    {
        {
            stack.Item().Text($"Invoice #{Model.InvoiceNumber}", titleStyle);

            stack.Item().Text(text =>
            {
                text.Span("Issue date: ", TextStyle.Default.SemiBold());
                text.Span($"{Model.IssueDate:d}");
            });

            stack.Item().Text(text =>
            {
                text.Span("Due date: ", TextStyle.Default.SemiBold());
                text.Span($"{Model.DueDate:d}");
            });
        });
        
        row.ConstantColumn(100).Height(50).Placeholder();
    });
}

Implementation of the content area that contains seller and customer details, then listing of all bought products, then a comments section.

void ComposeContent(IContainer container)
{
    container.PaddingVertical(40).Stack(column => 
    {
        column.Spacing(20);
        
        column.Item().Row(row =>
        {
            row.RelativeColumn().Component(new AddressComponent("From", Model.SellerAddress));
            row.ConstantColumn(50);
            row.RelativeColumn().Component(new AddressComponent("For", Model.CustomerAddress));
        });

        column.Item().Element(ComposeTable);

        var totalPrice = Model.Items.Sum(x => x.Price * x.Quantity);
        
        column
            .Item()
            .PaddingRight(5)
            .AlignRight()
            .Text($"Grand total: {totalPrice}$", TextStyle.Default.SemiBold());

        if (!string.IsNullOrWhiteSpace(Model.Comments))
            column.Item().PaddingTop(25).Element(ComposeComments);
    });
}

The table and comments codes are extracted into separate methods to increase clarity:

void ComposeTable(IContainer container)
{
    var headerStyle = TextStyle.Default.SemiBold();
    
    container.Decoration(decoration =>
    {
        // header
        decoration.Header().BorderBottom(1).Padding(5).Row(row => 
        {
            row.ConstantColumn(25).Text("#", headerStyle);
            row.RelativeColumn(3).Text("Product", headerStyle);
            row.RelativeColumn().AlignRight().Text("Unit price", headerStyle);
            row.RelativeColumn().AlignRight().Text("Quantity", headerStyle);
            row.RelativeColumn().AlignRight().Text("Total", headerStyle);
        });

        // content
        decoration
            .Content()
            .Stack(column =>
            {
                foreach (var item in Model.Items)
                {
                    column
                    .Item()
                    .ShowEntire()
                    .BorderBottom(1)
                    .BorderColor(Colors.Grey.Lighten2)
                    .Padding(5)
                    .Row(row => 
                    {
                        row.ConstantColumn(25).Text(Model.Items.IndexOf(item) + 1);
                        row.RelativeColumn(3).Text(item.Name);
                        row.RelativeColumn().AlignRight().Text($"{item.Price}$");
                        row.RelativeColumn().AlignRight().Text(item.Quantity);
                        row.RelativeColumn().AlignRight().Text($"{item.Price * item.Quantity}$");
                    });
                }
            });
    });
}
void ComposeComments(IContainer container)
{
    container.ShowEntire().Background(Colors.Grey.Lighten3).Padding(10).Stack(message => 
    {
        message.Spacing(5);
        message.Item().Text("Comments", TextStyle.Default.Size(14).SemiBold());
        message.Item().Text(Model.Comments);
    });
}

The address details section is implemented using components. This way the code can be easily reused for both seller and customer:

public class AddressComponent : IComponent
{
    private string Title { get; }
    private Address Address { get; }

    public AddressComponent(string title, Address address)
    {
        Title = title;
        Address = address;
    }
    
    public void Compose(IContainer container)
    {
        container.ShowEntire().Stack(column =>
        {
            column.Spacing(5);

            column
                .Item()
                .BorderBottom(1)
                .PaddingBottom(5)
                .Text(Title, TextStyle.Default.SemiBold());
            
            column.Item().Text(Address.CompanyName);
            column.Item().Text(Address.Street);
            column.Item().Text($"{Address.City}, {Address.State}");
            column.Item().Text(Address.Email);
            column.Item().Text(Address.Phone);
        });
    }
}
Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
.NET Core netcoreapp2.0 is compatible.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 is compatible.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 is compatible.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (59)

Showing the top 5 NuGet packages that depend on QuestPDF:

Package Downloads
HTMLToQPDF

Relorer.QuestPDF.HTML is an extension for QuestPDF that allows to generate PDF from HTML

AgentHub.Service.Financial.Domain.Shared

Package Description

DH.QuestPDF

DH框架的Pdf处理库。基于https://github.com/QuestPDF/QuestPDF

QuestPDF.Markdown

QuestPDF.Markdown is an open-source helper library that allows rendering markdown into a QuestPDF document

Verify.QuestPDF

Extends Verify (https://github.com/VerifyTests/Verify) to allow verification via QuestPDF.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
2025.12.0-alpha3 208 10/31/2025
2025.12.0-alpha2 1,813 10/8/2025
2025.12.0-alpha1 1,643 9/25/2025
2025.12.0-alpha0 1,930 9/5/2025
2025.7.4 572 11/3/2025
2025.7.3 53,271 10/14/2025
2025.7.2 78,804 9/25/2025
2025.7.1 168,992 8/27/2025
2025.7.0 347,601 7/3/2025
2025.6.0-rc0 671 6/25/2025
2025.5.1 155,924 6/5/2025
2025.5.0 170,139 5/15/2025
2025.4.4 49,590 5/12/2025
2025.4.3 82,914 5/5/2025
2025.4.2 34,639 5/1/2025
2025.4.1 1,547 5/1/2025
2025.4.0 235,931 4/7/2025
2025.1.7 139,346 3/21/2025
2025.1.6 87,735 3/13/2025
2025.1.5 138,376 3/3/2025
2025.1.4 28,144 2/28/2025
2025.1.3 72,696 2/20/2025
2025.1.2 84,264 2/8/2025
2025.1.1 46,915 2/3/2025
2025.1.0 31,997 2/2/2025
2025.1.0-rc0 3,380 1/24/2025
2025.1.0-alpha0 12,645 12/4/2024
2024.12.3 199,899 1/24/2025
2024.12.2 211,948 1/4/2025
2024.12.1 184,363 12/9/2024
2024.12.0 53,804 12/4/2024
2024.12.0-rc3 4,648 11/29/2024
2024.12.0-rc2 3,564 11/22/2024
2024.12.0-rc1 293 11/22/2024
2024.12.0-rc0 9,759 11/18/2024
2024.10.4 132,502 11/22/2024
2024.10.3 151,840 11/8/2024
2024.10.2 194,936 10/24/2024
2024.10.1 152,822 10/14/2024
2024.10.0 81,177 10/4/2024
2024.10.0-rc4 5,948 9/26/2024
2024.10.0-rc3 20,322 9/17/2024
2024.10.0-rc2 525 9/16/2024
2024.10.0-rc1 414 9/13/2024
2024.10.0-rc0 7,208 9/4/2024
2024.7.3 356,487 8/27/2024
2024.7.2 259,441 8/1/2024
2024.7.1 112,390 7/22/2024
2024.7.0 67,851 7/15/2024
2024.7.0-rc0 4,399 7/4/2024
2024.6.4 130,570 6/25/2024
2024.6.3 1,677 6/25/2024
2024.6.2 64,425 6/20/2024
2024.6.1 31,865 6/15/2024
2024.6.0 97,141 6/11/2024
2024.3.10 127,218 5/25/2024
2024.3.9 17,439 5/23/2024
2024.3.8 1,442 5/23/2024
2024.3.7 37,884 5/20/2024
2024.3.6 53,579 5/14/2024
2024.3.5 40,262 5/12/2024
2024.3.4 48,095 5/6/2024
2024.3.3 17,423 5/2/2024
2024.3.2 64,118 4/25/2024
2024.3.1 57,095 4/22/2024
2024.3.0 132,886 4/12/2024
2024.3.0-rc2 6,524 3/30/2024
2024.3.0-rc1 352 3/29/2024
2024.3.0-rc 742 3/27/2024
2024.3.0-beta1 3,615 3/18/2024
2024.3.0-beta 4,889 2/29/2024
2024.3.0-alpha 1,930 2/15/2024
2023.12.6 460,852 2/21/2024
2023.12.5 107,430 2/7/2024
2023.12.4 224,974 1/15/2024
2023.12.3 24,902 1/12/2024
2023.12.2 93,565 1/1/2024
2023.12.1 101,797 12/15/2023
2023.12.0 70,767 12/3/2023
2023.10.2 111,055 11/13/2023
2023.10.1 64,645 10/31/2023
2023.10.0 40,784 10/23/2023
2023.10.0-alpha0 482 10/13/2023
2023.9.1 63,953 10/6/2023
2023.9.0 50,075 9/25/2023
2023.6.3 187,031 8/27/2023
2023.6.2 1,338 8/26/2023
2023.6.1 142,597 7/20/2023
2023.6.0 121,326 6/28/2023
2023.5.3 228,463 6/12/2023
2023.5.2 82,346 5/31/2023
2023.5.1 35,750 5/22/2023
2023.5.0 14,376 5/15/2023
2023.4.2 17,876 5/9/2023
2023.4.1 6,275 5/4/2023
2023.4.0 4,342 5/4/2023
2022.12.15 720,001 2/7/2024
2022.12.14 77,136 1/12/2024
2022.12.13 13,115 1/1/2024
2022.12.12 33,541 12/15/2023
2022.12.11 42,322 12/3/2023
2022.12.10 15,971 11/13/2023
2022.12.9 4,093 10/31/2023
2022.12.8 58,295 10/23/2023
2022.12.7 123,197 10/6/2023
2022.12.6 618,487 5/9/2023
2022.12.5 186,911 4/27/2023
2022.12.4 55,839 4/22/2023
2022.12.3 83,892 4/16/2023
2022.12.2 413,646 3/12/2023
2022.12.1 712,451 1/13/2023
2022.12.0 187,014 12/14/2022
2022.11.0 451,926 11/5/2022
2022.11.0-alpha1 506 11/1/2022
2022.11.0-alpha0 474 10/28/2022
2022.9.1 106,038 10/15/2022
2022.9.0 166,965 9/18/2022
2022.9.0-alpha1 446 9/16/2022
2022.8.2 208,191 8/21/2022
2022.8.1 21,233 8/19/2022
2022.8.0 116,220 8/15/2022
2022.6.3 65,870 7/18/2022
2022.6.2 179,459 6/22/2022
2022.6.1 25,075 6/12/2022
2022.6.0 170,725 6/12/2022
2022.6.0-prerelease 2,025 5/30/2022
2022.5.0 313,427 5/9/2022
2022.4.1 127,866 4/8/2022
2022.4.0 80,106 4/4/2022
2022.4.0-alpha1 501 3/27/2022
2022.4.0-alpha0 458 3/27/2022
2022.3.1 107,409 3/15/2022
2022.3.0 3,521 3/14/2022
2022.2.7 1,957 3/12/2022
2022.2.6 6,842 3/8/2022
2022.2.5 23,682 2/18/2022
2022.2.4 890 2/18/2022
2022.2.3 12,280 2/7/2022
2022.2.2 2,249 2/1/2022
2022.2.1 1,970 1/30/2022
2022.2.0 2,106 1/29/2022
2022.2.0-beta1 511 1/24/2022
2022.1.0 33,135 1/10/2022
2022.1.0-beta5 1,155 1/7/2022
2022.1.0-beta4 529 1/6/2022
2022.1.0-beta3 488 1/5/2022
2022.1.0-beta2 506 1/5/2022
2022.1.0-beta1 521 1/3/2022
2022.1.0-beta0 486 12/30/2021
2022.1.0-alpha0 627 12/30/2021 2022.1.0-alpha0 is deprecated because it is no longer maintained.
2021.12.0 37,717 12/6/2021
2021.12.0-alpha1 1,363 11/29/2021
2021.12.0-alpha0 556 11/18/2021
2021.11.4 24,886 11/14/2021
2021.11.3 5,201 11/7/2021
2021.11.0-beta3 574 11/3/2021
2021.11.0-beta2 604 10/28/2021
2021.11.0-beta 651 10/23/2021
2021.10.1 10,573 9/30/2021
2021.10.0 824 9/30/2021
2021.10.0-beta.2 427 9/14/2021
2021.10.0-beta 578 9/13/2021
2021.9.3 8,691 9/12/2021
2021.9.2 917 9/1/2021
2021.9.1 745 9/1/2021
2021.9.0 710 8/30/2021
2021.8.0 2,700 8/2/2021
2021.5.2 4,586 5/5/2021
2021.4.0 971 4/2/2021
2021.3.1 7,348 3/1/2021
2021.3.0 797 3/1/2021
2021.2.0 921 2/8/2021
2021.1.0 924 1/4/2021
2020.11.0 14,977 11/1/2020

Introduced new element: `Table` - a great way to construct complex document structures, e.g. reports. This element covers all cases offered by combination of the `Stack` and the `Row` elements. Additionally, it provides support for more complex layouts and corner cases. Updating to the `Table` element can greatly simplify your code 😁

Other changes:
- Added new element `DefaultTextStyle` - it allows set new text style to all its children,
- Improved the default paging behavior for the `Row` element. In some minor corner cases it might cause infinite layout exceptions and confuse developers.
- Improved the `Row` element: added new type of column that combines constant and relative widths.
- Fixed default page sizes for: Letter and Legal.