HtmlSettings.cs
//
// This code is part of Document Solutions for PDF demos.
// Copyright (c) MESCIUS inc. All rights reserved.
//
using System;
using System.IO;
using System.Drawing;
using GrapeCity.Documents.Pdf;
using GrapeCity.Documents.Text;
using GrapeCity.Documents.Html;

namespace DsPdfWeb.Demos
{
    // This sample shows how to render a web page specified by a URL
    // to a PDF. Here we render the C# source of the WordIndex sample.
    // Similar to HtmlRenderPage0, this sample directly uses GcHtmlRenderer,
    // but shows how to specify options such as page orientation, margins,
    // headers and footers.
    //
    // For reference, the following markup extensions can be used in the
    // header and title templates (all except title are used in this sample):
    // - <span class="date">       - Formatted date
    // - <span class="title">      - Document title
    // - <span class="url">        - Document location
    // - <span class="pageNumber"> - Current page number
    // - <span class="totalPages"> - Total number of pages
    //
    // Note that in headers/footers images cannot be specified as links,
    // but base64 encoded data is supported as shown in this sample.
    //
    // Also note that for background colors in headers/footers to appear,
    // the following webkit CSS extension should be specified:
    // -webkit-print-color-adjust: exact;
    //
    // Please see notes in comments at the top of HelloWorldHtml
    // sample code for details on adding DsHtml to your projects.
    public class HtmlSettings
    {
        public void CreatePDF(Stream stream)
        {
            // Get a temporary file where the web page will be rendered:
            var tmp = Path.GetTempFileName();
            // The Uri of the web page to render:
            var uri = new Uri(@"https://developer.mescius.com/document-solutions/dot-net-pdf-api/demos/view-source-cs/word-index/");
            // Image used in the footer template:
            var image = @"";

            // PdfOptions is used to provide options for HTML to PDF conversion:
            // - PageRanges specifies which pages to include.
            // - PageWidth/PageHeight allow customizing page size (defaults are used here for demo).
            // - Margins specify page margins (the default is no margins).
            // - Landscape allows changing page orientation.
            // - Scale allows enlarging or reducing the render size (default is 1).
            // - To add custom headers, DisplayHeaderFooter needs to be set to true.
            // - HeaderTemplate/FooterTemplate allow specifying custom page headers.
            var pdfOptions = new PdfOptions()
            {
                PageRanges = "2-100",
                PageWidth = 8.5f,
                PageHeight = 11f,
                Margins = new PdfMargins(0.2f, 1, 0.2f, 1),
                Landscape = true,
                DisplayHeaderFooter = true,
                HeaderTemplate = "<div style='-webkit-print-color-adjust:exact;background-color:#395daa;color:white;" +
                    "padding:0.1in;font-size:12em;width:1000px;margin-left:0.2in;margin-right:0.2in'>" +
                    "<span style='float:left'>Page <span class='pageNumber'></span> of <span class='totalPages'></span></span>" +
                    "<span style='float:right'>Document created on <span class='date'></span>" +
                    "</div>",
                FooterTemplate = "<div style='font-size:12em;width:1000px;margin-left:0.2in;margin-right:0.2in'>" +
                    $"<span>Document location: <span class='url'></span><img style='float:right;' width='40' height='40' src='{image}'></img></div>"
            };

            // Create an instance of GcHtmlBrowser that is used to render HTML:
            using var browser = Common.Util.NewHtmlBrowser();

            // Render the source Web page to the temporary file:
            using var htmlPage = browser.NewPage(uri);
            htmlPage.SaveAsPdf(tmp, pdfOptions);

            // Copy the created PDF from the temp file to target stream:
            using (var ts = File.OpenRead(tmp))
                ts.CopyTo(stream);
            // Clean up:
            File.Delete(tmp);
            // Done.
        }
    }
}