How to Print Invoice in C#

By FoxLearn 12/2/2024 3:14:10 PM   12.14K
To create an invoice, receipt, or order using DevExpress XtraReport in C#, you will need to follow a few steps.

DevExpress provides powerful tools for creating custom reports, and you can use XtraReport to design and generate reports.

How to Print Invoice in C#?

Open Visual Studio, then click New Project, then select Visual C# on the left, then Windows and then select Windows Forms Application. Name your project "DevReport" and then click OK

Design your form as shown below.

If you have not yet installed DevExpress .NET products, you can view How to download and install DevExpress

Your main form name: Form1

devexpress report

Your print form name: frmPrint

devexpress report

Add a connection string to the App.config file in your C# project. This connection string will contain the necessary details to connect to your database.

<connectionStrings>
    <add name="cn" connectionString="Data Source=.;Initial Catalog=Northwind;User ID=sa;Password=123@qaz;" providerName="System.Data.SqlClient"/>
</connectionStrings>

We use the Northwind database to play demo. If you haven't got Northwind database, you can view How to download and restore Northwind database in SQL Server

You can install Dapper using the following command in the NuGet Package Manager Console, then create Orders and OrderDetail class to map data return from the northwind database.

Install-Package Dapper

Dapper is a simple Object-Relational Mapper (ORM) that simplifies database interactions in C#.

We will create two classes: Orders and OrderDetail, which will map to the corresponding database tables.

public class Orders
{
    public int OrderID { get; set; }
    public string CustomerID { get; set; }
    [Display(Name = "Contact Name")]
    public string ContactName { get; set; }
    public string Address { get; set; }
    [Display(Name = "Postal Code")]
    public string PostalCode { get; set; }
    public string City { get; set; }
    public string Phone { get; set; }
    public DateTime OrderDate { get; set; }
}
public class OrderDetail
{
    public int OrderID { get; set; }
    [Display(Name = "Product Name")]
    public string ProductName { get; set; }
    public int Quantity { get; set; }
    public decimal Discount { get; set; }
    [Display(Name = "Unit Price")]
    public decimal UnitPrice { get; set; }
    public decimal Total
    {
        get
        {
            return Quantity * UnitPrice - Quantity * UnitPrice * Discount;
        }
    }
}

We'll design an invoice report to show the order details.

devexpress xtrareport

In the frmPrint form, we will create a method to print the invoice. This method will receive the order and order details as parameters, initialize the report with this data, and display it.

frmPrint

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Linq;
using System.Threading.Tasks;
using System.Windows.Forms;
using DevExpress.XtraEditors;

namespace DevReport
{
    public partial class frmPrint : DevExpress.XtraEditors.XtraForm
    {
        public frmPrint()
        {
            InitializeComponent();
        }

        public void PrintInvoice(Orders order, List<OrderDetail> data)
        {
            InvoiceReport report = new InvoiceReport();
            //Hide paramater
            foreach (DevExpress.XtraReports.Parameters.Parameter p in report.Parameters)
                p.Visible = false;
            //Init data report
            report.InitData(order.OrderID.ToString(), order.OrderDate, order.ContactName, order.Address, order.PostalCode, order.City, order.Phone, data);
            documentViewer1.DocumentSource = report;
            report.CreateDocument();
        }
    }
}

In Form1, you can load data from the database using Dapper, and then pass the data to the frmPrint form for printing.

Form1

using System;
using System.Collections.Generic;
using System.Configuration;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using Dapper;
using DevExpress.XtraEditors;

namespace DevReport
{
    public partial class Form1 : XtraForm
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void btnPrint_Click(object sender, EventArgs e)
        {
            Orders obj = ordersBindingSource.Current as Orders;
            if (obj != null)
            {
                using (IDbConnection db = new SqlConnection(ConfigurationManager.ConnectionStrings["cn"].ConnectionString))
                {
                    if (db.State == ConnectionState.Closed)
                        db.Open();
                    // Execute query to get data from Orders and OrderDetails table
                    string query = "select d.OrderID, p.ProductName, d.Quantity, d.Discount, d.UnitPrice from [Order Details] d inner join Products p on d.ProductID = p.ProductID" +
                                    $" where d.OrderID = '{obj.OrderID}'";
                    List<OrderDetail> list = db.Query<OrderDetail>(query, commandType: CommandType.Text).ToList();
                    // Open print form dialog
                    using (frmPrint frm = new frmPrint())
                    {
                        frm.PrintInvoice(obj, list);
                        frm.ShowDialog();
                    }
                }
            }
        }

        private void btnLoad_Click(object sender, EventArgs e)
        {
            using (IDbConnection db = new SqlConnection(ConfigurationManager.ConnectionStrings["cn"].ConnectionString))
            {
                if (db.State == ConnectionState.Closed)
                    db.Open();
                // Execute query to get data from Orders table
                string query = "select o.OrderID, c.CustomerID, c.ContactName, c.Address, c.PostalCode, c.City, c.Phone, o.OrderDate" +
                                 " from Orders o inner join Customers c on o.CustomerID = c.CustomerID" +
                                $" where o.OrderDate between convert(varchar(25),'{dtFromDate.EditValue}',103) and convert(varchar(25),'{dtToDate.EditValue}',103)";
                ordersBindingSource.DataSource = db.Query<Orders>(query, commandType: CommandType.Text);
            }
        }
    }
}

VIDEO TUTORIAL