├── PagingInWPF.PNG ├── PagingWPFDataGrid ├── App.config ├── Properties │ ├── Settings.settings │ ├── Settings.Designer.cs │ ├── AssemblyInfo.cs │ ├── Resources.Designer.cs │ └── Resources.resx ├── App.xaml.cs ├── App.xaml ├── StudentModel.cs ├── MainWindow.xaml.cs ├── PagingWPFDataGrid.csproj ├── MainWindow.xaml └── Paging.cs ├── README.md ├── PagingWPFDataGrid.sln ├── .gitattributes └── .gitignore /PagingInWPF.PNG: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WyoMetz/Paging-WPF-DataGrid/HEAD/PagingInWPF.PNG -------------------------------------------------------------------------------- /PagingWPFDataGrid/App.config: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | -------------------------------------------------------------------------------- /PagingWPFDataGrid/Properties/Settings.settings: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | -------------------------------------------------------------------------------- /PagingWPFDataGrid/App.xaml.cs: -------------------------------------------------------------------------------- 1 | using System; 2 | using System.Collections.Generic; 3 | using System.Configuration; 4 | using System.Data; 5 | using System.Linq; 6 | using System.Threading.Tasks; 7 | using System.Windows; 8 | 9 | namespace PagingWPFDataGrid 10 | { 11 | /// 12 | /// Interaction logic for App.xaml 13 | /// 14 | public partial class App : Application 15 | { 16 | } 17 | } 18 | -------------------------------------------------------------------------------- /PagingWPFDataGrid/App.xaml: -------------------------------------------------------------------------------- 1 | 6 | 7 | 19 | 20 | 21 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Paging-WPF-DataGrid 2 | 3 | ![Screenshot](PagingInWPF.PNG) 4 | 5 | This is an Example on Paging a WPF DataGrid with a DataTable. The DataGrid is interacted with by the user via buttons and the Code is simple and easy to replicate. Not yet fully generic. 6 | 7 | This DataGrid Pager takes an IList (or Enumerable of any kind) of a specified class type and outputs the LINQ Query to a DataTable to be used in a DataGrid (or any other display that accepts a DataTable). The DataTable can be bound to the DataGrid in XAML, but for clarity this example does not do that. 8 | 9 | This Example is not fully generic (yet, still learning type properties) and will require modification for each list that this Pager is used on unless the list is fully generic. 10 | 11 | If you can figure out how to convert the Paging Class into a fully generic operation accepting any range of type, Please Open a Pull Request! 12 | 13 | The Repo is heavily commented. All of the Paging work is done in the Paging Class. 14 | -------------------------------------------------------------------------------- /PagingWPFDataGrid/Properties/Settings.Designer.cs: -------------------------------------------------------------------------------- 1 | //------------------------------------------------------------------------------ 2 | // 3 | // This code was generated by a tool. 4 | // Runtime Version:4.0.30319.42000 5 | // 6 | // Changes to this file may cause incorrect behavior and will be lost if 7 | // the code is regenerated. 8 | // 9 | //------------------------------------------------------------------------------ 10 | 11 | namespace PagingWPFDataGrid.Properties 12 | { 13 | 14 | 15 | [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] 16 | [global::System.CodeDom.Compiler.GeneratedCodeAttribute("Microsoft.VisualStudio.Editors.SettingsDesigner.SettingsSingleFileGenerator", "11.0.0.0")] 17 | internal sealed partial class Settings : global::System.Configuration.ApplicationSettingsBase 18 | { 19 | 20 | private static Settings defaultInstance = ((Settings)(global::System.Configuration.ApplicationSettingsBase.Synchronized(new Settings()))); 21 | 22 | public static Settings Default 23 | { 24 | get 25 | { 26 | return defaultInstance; 27 | } 28 | } 29 | } 30 | } 31 | -------------------------------------------------------------------------------- /PagingWPFDataGrid.sln: -------------------------------------------------------------------------------- 1 | 2 | Microsoft Visual Studio Solution File, Format Version 12.00 3 | # Visual Studio 15 4 | VisualStudioVersion = 15.0.28010.2003 5 | MinimumVisualStudioVersion = 10.0.40219.1 6 | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "PagingWPFDataGrid", "PagingWPFDataGrid\PagingWPFDataGrid.csproj", "{C6DCDEDE-B826-4298-AFBB-4DD6689A2CB8}" 7 | EndProject 8 | Global 9 | GlobalSection(SolutionConfigurationPlatforms) = preSolution 10 | Debug|Any CPU = Debug|Any CPU 11 | Release|Any CPU = Release|Any CPU 12 | EndGlobalSection 13 | GlobalSection(ProjectConfigurationPlatforms) = postSolution 14 | {C6DCDEDE-B826-4298-AFBB-4DD6689A2CB8}.Debug|Any CPU.ActiveCfg = Debug|Any CPU 15 | {C6DCDEDE-B826-4298-AFBB-4DD6689A2CB8}.Debug|Any CPU.Build.0 = Debug|Any CPU 16 | {C6DCDEDE-B826-4298-AFBB-4DD6689A2CB8}.Release|Any CPU.ActiveCfg = Release|Any CPU 17 | {C6DCDEDE-B826-4298-AFBB-4DD6689A2CB8}.Release|Any CPU.Build.0 = Release|Any CPU 18 | EndGlobalSection 19 | GlobalSection(SolutionProperties) = preSolution 20 | HideSolutionNode = FALSE 21 | EndGlobalSection 22 | GlobalSection(ExtensibilityGlobals) = postSolution 23 | SolutionGuid = {34CD48F3-5F31-4DAB-92B9-E203E76ECBD1} 24 | EndGlobalSection 25 | EndGlobal 26 | -------------------------------------------------------------------------------- /PagingWPFDataGrid/StudentModel.cs: -------------------------------------------------------------------------------- 1 | using System; 2 | using System.Collections.Generic; 3 | using System.Linq; 4 | using System.Text; 5 | using System.Threading.Tasks; 6 | 7 | namespace PagingWPFDataGrid 8 | { 9 | /// 10 | /// Generic Class Model Adopted from https://www.codeproject.com/Articles/1092189/WPF-Pagination-for-DataGrid 11 | /// 12 | class StudentModel 13 | { 14 | public class Student 15 | { 16 | public string FirstName { get; set; } 17 | public string MiddleName { get; set; } 18 | public string LastName { get; set; } 19 | public int Age { get; set; } 20 | } 21 | 22 | 23 | public IList GetData() 24 | { 25 | List genericList = new List(); 26 | Student studentObj; 27 | Random randomObj = new Random(); 28 | for (int i = 0; i < 12345; i++) //You can make this number anything you can think of (and your processor can handle). 29 | { 30 | studentObj = new Student 31 | { 32 | FirstName = "first " + i, 33 | MiddleName = "Middle " + i, 34 | LastName = "Last " + i, 35 | Age = (int)randomObj.Next(1, 100) 36 | }; 37 | 38 | genericList.Add(studentObj); 39 | 40 | } 41 | return genericList; 42 | } 43 | } 44 | } 45 | -------------------------------------------------------------------------------- /PagingWPFDataGrid/Properties/AssemblyInfo.cs: -------------------------------------------------------------------------------- 1 | using System.Reflection; 2 | using System.Resources; 3 | using System.Runtime.CompilerServices; 4 | using System.Runtime.InteropServices; 5 | using System.Windows; 6 | 7 | // General Information about an assembly is controlled through the following 8 | // set of attributes. Change these attribute values to modify the information 9 | // associated with an assembly. 10 | [assembly: AssemblyTitle("PagingWPFDataGrid")] 11 | [assembly: AssemblyDescription("")] 12 | [assembly: AssemblyConfiguration("")] 13 | [assembly: AssemblyCompany("")] 14 | [assembly: AssemblyProduct("PagingWPFDataGrid")] 15 | [assembly: AssemblyCopyright("Copyright © 2018")] 16 | [assembly: AssemblyTrademark("")] 17 | [assembly: AssemblyCulture("")] 18 | 19 | // Setting ComVisible to false makes the types in this assembly not visible 20 | // to COM components. If you need to access a type in this assembly from 21 | // COM, set the ComVisible attribute to true on that type. 22 | [assembly: ComVisible(false)] 23 | 24 | //In order to begin building localizable applications, set 25 | //CultureYouAreCodingWith in your .csproj file 26 | //inside a . For example, if you are using US english 27 | //in your source files, set the to en-US. Then uncomment 28 | //the NeutralResourceLanguage attribute below. Update the "en-US" in 29 | //the line below to match the UICulture setting in the project file. 30 | 31 | //[assembly: NeutralResourcesLanguage("en-US", UltimateResourceFallbackLocation.Satellite)] 32 | 33 | 34 | [assembly: ThemeInfo( 35 | ResourceDictionaryLocation.None, //where theme specific resource dictionaries are located 36 | //(used if a resource is not found in the page, 37 | // or application resource dictionaries) 38 | ResourceDictionaryLocation.SourceAssembly //where the generic resource dictionary is located 39 | //(used if a resource is not found in the page, 40 | // app, or any theme specific resource dictionaries) 41 | )] 42 | 43 | 44 | // Version information for an assembly consists of the following four values: 45 | // 46 | // Major Version 47 | // Minor Version 48 | // Build Number 49 | // Revision 50 | // 51 | // You can specify all the values or you can default the Build and Revision Numbers 52 | // by using the '*' as shown below: 53 | // [assembly: AssemblyVersion("1.0.*")] 54 | [assembly: AssemblyVersion("1.0.0.0")] 55 | [assembly: AssemblyFileVersion("1.0.0.0")] 56 | -------------------------------------------------------------------------------- /.gitattributes: -------------------------------------------------------------------------------- 1 | ############################################################################### 2 | # Set default behavior to automatically normalize line endings. 3 | ############################################################################### 4 | * text=auto 5 | 6 | ############################################################################### 7 | # Set default behavior for command prompt diff. 8 | # 9 | # This is need for earlier builds of msysgit that does not have it on by 10 | # default for csharp files. 11 | # Note: This is only used by command line 12 | ############################################################################### 13 | #*.cs diff=csharp 14 | 15 | ############################################################################### 16 | # Set the merge driver for project and solution files 17 | # 18 | # Merging from the command prompt will add diff markers to the files if there 19 | # are conflicts (Merging from VS is not affected by the settings below, in VS 20 | # the diff markers are never inserted). Diff markers may cause the following 21 | # file extensions to fail to load in VS. An alternative would be to treat 22 | # these files as binary and thus will always conflict and require user 23 | # intervention with every merge. To do so, just uncomment the entries below 24 | ############################################################################### 25 | #*.sln merge=binary 26 | #*.csproj merge=binary 27 | #*.vbproj merge=binary 28 | #*.vcxproj merge=binary 29 | #*.vcproj merge=binary 30 | #*.dbproj merge=binary 31 | #*.fsproj merge=binary 32 | #*.lsproj merge=binary 33 | #*.wixproj merge=binary 34 | #*.modelproj merge=binary 35 | #*.sqlproj merge=binary 36 | #*.wwaproj merge=binary 37 | 38 | ############################################################################### 39 | # behavior for image files 40 | # 41 | # image files are treated as binary by default. 42 | ############################################################################### 43 | #*.jpg binary 44 | #*.png binary 45 | #*.gif binary 46 | 47 | ############################################################################### 48 | # diff behavior for common document formats 49 | # 50 | # Convert binary document formats to text before diffing them. This feature 51 | # is only available from the command line. Turn it on by uncommenting the 52 | # entries below. 53 | ############################################################################### 54 | #*.doc diff=astextplain 55 | #*.DOC diff=astextplain 56 | #*.docx diff=astextplain 57 | #*.DOCX diff=astextplain 58 | #*.dot diff=astextplain 59 | #*.DOT diff=astextplain 60 | #*.pdf diff=astextplain 61 | #*.PDF diff=astextplain 62 | #*.rtf diff=astextplain 63 | #*.RTF diff=astextplain 64 | -------------------------------------------------------------------------------- /PagingWPFDataGrid/Properties/Resources.Designer.cs: -------------------------------------------------------------------------------- 1 | //------------------------------------------------------------------------------ 2 | // 3 | // This code was generated by a tool. 4 | // Runtime Version:4.0.30319.42000 5 | // 6 | // Changes to this file may cause incorrect behavior and will be lost if 7 | // the code is regenerated. 8 | // 9 | //------------------------------------------------------------------------------ 10 | 11 | namespace PagingWPFDataGrid.Properties 12 | { 13 | 14 | 15 | /// 16 | /// A strongly-typed resource class, for looking up localized strings, etc. 17 | /// 18 | // This class was auto-generated by the StronglyTypedResourceBuilder 19 | // class via a tool like ResGen or Visual Studio. 20 | // To add or remove a member, edit your .ResX file then rerun ResGen 21 | // with the /str option, or rebuild your VS project. 22 | [global::System.CodeDom.Compiler.GeneratedCodeAttribute("System.Resources.Tools.StronglyTypedResourceBuilder", "4.0.0.0")] 23 | [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] 24 | [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] 25 | internal class Resources 26 | { 27 | 28 | private static global::System.Resources.ResourceManager resourceMan; 29 | 30 | private static global::System.Globalization.CultureInfo resourceCulture; 31 | 32 | [global::System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1811:AvoidUncalledPrivateCode")] 33 | internal Resources() 34 | { 35 | } 36 | 37 | /// 38 | /// Returns the cached ResourceManager instance used by this class. 39 | /// 40 | [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] 41 | internal static global::System.Resources.ResourceManager ResourceManager 42 | { 43 | get 44 | { 45 | if ((resourceMan == null)) 46 | { 47 | global::System.Resources.ResourceManager temp = new global::System.Resources.ResourceManager("PagingWPFDataGrid.Properties.Resources", typeof(Resources).Assembly); 48 | resourceMan = temp; 49 | } 50 | return resourceMan; 51 | } 52 | } 53 | 54 | /// 55 | /// Overrides the current thread's CurrentUICulture property for all 56 | /// resource lookups using this strongly typed resource class. 57 | /// 58 | [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] 59 | internal static global::System.Globalization.CultureInfo Culture 60 | { 61 | get 62 | { 63 | return resourceCulture; 64 | } 65 | set 66 | { 67 | resourceCulture = value; 68 | } 69 | } 70 | } 71 | } 72 | -------------------------------------------------------------------------------- /PagingWPFDataGrid/MainWindow.xaml.cs: -------------------------------------------------------------------------------- 1 | using System; 2 | using System.Collections.Generic; 3 | using System.Data; 4 | using System.Windows; 5 | using System.Windows.Controls; 6 | 7 | namespace PagingWPFDataGrid 8 | { 9 | /// 10 | /// Interaction logic for MainWindow.xaml 11 | /// 12 | public partial class MainWindow : Window 13 | { 14 | private int numberOfRecPerPage; //Initialize our Variable, Classes and the List 15 | 16 | static Paging PagedTable = new Paging(); 17 | 18 | static StudentModel StudentList = new StudentModel(); 19 | 20 | IList myList = StudentList.GetData(); 21 | 22 | public MainWindow() 23 | { 24 | InitializeComponent(); 25 | 26 | PagedTable.PageIndex = 1; //Sets the Initial Index to a default value 27 | 28 | int[] RecordsToShow = { 10, 20, 30, 50, 100 }; //This Array can be any number groups 29 | 30 | foreach (int RecordGroup in RecordsToShow) 31 | { 32 | NumberOfRecords.Items.Add(RecordGroup); //Fill the ComboBox with the Array 33 | } 34 | 35 | NumberOfRecords.SelectedItem = 10; //Initialize the ComboBox 36 | 37 | numberOfRecPerPage = Convert.ToInt32(NumberOfRecords.SelectedItem); //Convert the Combox Output to type int 38 | 39 | DataTable firstTable = PagedTable.SetPaging(myList, numberOfRecPerPage); //Fill a DataTable with the First set based on the numberOfRecPerPage 40 | 41 | dataGrid.ItemsSource = firstTable.DefaultView; //Fill the dataGrid with the DataTable created previously 42 | } 43 | 44 | /// 45 | /// Determines the shown number of records and returns that as a string 46 | /// 47 | /// string Number of Records Showing 48 | public string PageNumberDisplay() 49 | { 50 | int PagedNumber = numberOfRecPerPage * (PagedTable.PageIndex + 1); 51 | if (PagedNumber > myList.Count) 52 | { 53 | PagedNumber = myList.Count; 54 | } 55 | return "Showing " + PagedNumber + " of " + myList.Count; //This dramatically reduced the number of times I had to write this string statement 56 | } 57 | 58 | private void Forward_Click(object sender, RoutedEventArgs e) //For each of these you call the direction you want and pass in the List and ComboBox output 59 | { //and use the above function to output the Record number to the Label 60 | dataGrid.ItemsSource = PagedTable.Next(myList, numberOfRecPerPage).DefaultView; 61 | PageInfo.Content = PageNumberDisplay(); 62 | } 63 | 64 | private void Backwards_Click(object sender, RoutedEventArgs e) 65 | { 66 | dataGrid.ItemsSource = PagedTable.Previous(myList, numberOfRecPerPage).DefaultView; 67 | PageInfo.Content = PageNumberDisplay(); 68 | } 69 | 70 | private void NumberOfRecords_SelectionChanged(object sender, SelectionChangedEventArgs e) //I couldn't get this function to update in place (if the grid showed 20 and I selected 100 it would jump to 200) 71 | { //So instead I had it call the First function and that does an acceptable job. 72 | numberOfRecPerPage = Convert.ToInt32(NumberOfRecords.SelectedItem); 73 | dataGrid.ItemsSource = PagedTable.First(myList, numberOfRecPerPage).DefaultView; 74 | PageInfo.Content = PageNumberDisplay(); 75 | } 76 | 77 | private void First_Click(object sender, RoutedEventArgs e) 78 | { 79 | dataGrid.ItemsSource = PagedTable.First(myList, numberOfRecPerPage).DefaultView; 80 | PageInfo.Content = PageNumberDisplay(); 81 | } 82 | 83 | private void Last_Click(object sender, RoutedEventArgs e) 84 | { 85 | dataGrid.ItemsSource = PagedTable.Last(myList, numberOfRecPerPage).DefaultView; 86 | PageInfo.Content = PageNumberDisplay(); 87 | } 88 | } 89 | } 90 | -------------------------------------------------------------------------------- /PagingWPFDataGrid/PagingWPFDataGrid.csproj: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | Debug 6 | AnyCPU 7 | {C6DCDEDE-B826-4298-AFBB-4DD6689A2CB8} 8 | WinExe 9 | PagingWPFDataGrid 10 | PagingWPFDataGrid 11 | v4.6.1 12 | 512 13 | {60dc8134-eba5-43b8-bcc9-bb4bc16c2548};{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC} 14 | 4 15 | true 16 | true 17 | 18 | 19 | AnyCPU 20 | true 21 | full 22 | false 23 | bin\Debug\ 24 | DEBUG;TRACE 25 | prompt 26 | 4 27 | 28 | 29 | AnyCPU 30 | pdbonly 31 | true 32 | bin\Release\ 33 | TRACE 34 | prompt 35 | 4 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 4.0 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | MSBuild:Compile 56 | Designer 57 | 58 | 59 | 60 | MSBuild:Compile 61 | Designer 62 | 63 | 64 | App.xaml 65 | Code 66 | 67 | 68 | MainWindow.xaml 69 | Code 70 | 71 | 72 | 73 | 74 | 75 | Code 76 | 77 | 78 | True 79 | True 80 | Resources.resx 81 | 82 | 83 | True 84 | Settings.settings 85 | True 86 | 87 | 88 | ResXFileCodeGenerator 89 | Resources.Designer.cs 90 | 91 | 92 | SettingsSingleFileGenerator 93 | Settings.Designer.cs 94 | 95 | 96 | 97 | 98 | 99 | 100 | -------------------------------------------------------------------------------- /PagingWPFDataGrid/MainWindow.xaml: -------------------------------------------------------------------------------- 1 | 12 | 13 | 15 | 17 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 46 | 47 | 48 | 49 | 50 | 52 | 54 | 55 | 56 | 57 | 63 | 66 | 71 | 76 | 79 | 82 | 85 | 88 | 89 | 94 | 99 | 100 | 101 | 105 | 108 | 109 | 110 | 111 | 112 | 113 | 114 | 115 | -------------------------------------------------------------------------------- /PagingWPFDataGrid/Paging.cs: -------------------------------------------------------------------------------- 1 | using System; 2 | using System.Collections.Generic; 3 | using System.Data; 4 | using System.Linq; 5 | 6 | namespace PagingWPFDataGrid 7 | { 8 | /// 9 | /// Performs Paging operations on a given List and Outputs a DataTable 10 | /// 11 | class Paging 12 | { 13 | /// 14 | /// Current Page Index Number 15 | /// 16 | public int PageIndex { get; set; } 17 | 18 | DataTable PagedList = new DataTable(); //Initialize a DataTable Locally 19 | 20 | /// 21 | /// Show the next set of Items based on page index 22 | /// 23 | /// 24 | /// 25 | /// DataTable 26 | public DataTable Next(IList ListToPage, int RecordsPerPage) 27 | { 28 | PageIndex++; 29 | if (PageIndex >= ListToPage.Count / RecordsPerPage) 30 | { 31 | PageIndex = ListToPage.Count / RecordsPerPage; 32 | } 33 | PagedList = SetPaging(ListToPage, RecordsPerPage); 34 | return PagedList; 35 | } 36 | 37 | /// 38 | /// Show the previous set of items base on page index 39 | /// 40 | /// 41 | /// 42 | /// DataTable 43 | public DataTable Previous(IList ListToPage, int RecordsPerPage) 44 | { 45 | PageIndex--; 46 | if(PageIndex <= 0) 47 | { 48 | PageIndex = 0; 49 | } 50 | PagedList = SetPaging(ListToPage, RecordsPerPage); 51 | return PagedList; 52 | } 53 | 54 | /// 55 | /// Show first the set of Items in the page index 56 | /// 57 | /// 58 | /// 59 | /// DataTable 60 | public DataTable First(IList ListToPage, int RecordsPerPage) 61 | { 62 | PageIndex = 0; 63 | PagedList = SetPaging(ListToPage, RecordsPerPage); 64 | return PagedList; 65 | } 66 | 67 | /// 68 | /// Show the last set of items in the page index 69 | /// 70 | /// 71 | /// 72 | /// DataTable 73 | public DataTable Last(IList ListToPage, int RecordsPerPage) 74 | { 75 | PageIndex = ListToPage.Count / RecordsPerPage; 76 | PagedList = SetPaging(ListToPage, RecordsPerPage); 77 | return PagedList; 78 | } 79 | 80 | /// 81 | /// Performs a LINQ Query on the List and returns a DataTable 82 | /// 83 | /// 84 | /// 85 | /// DataTable 86 | public DataTable SetPaging(IList ListToPage, int RecordsPerPage) 87 | { 88 | int PageGroup = PageIndex * RecordsPerPage; 89 | 90 | IList PagedList = new List(); 91 | 92 | PagedList = ListToPage.Skip(PageGroup).Take(RecordsPerPage).ToList(); //This is where the Magic Happens. If you have a Specific sort or want to return ONLY a specific set of columns, add it to this LINQ Query. 93 | 94 | DataTable FinalPaging = PagedTable(PagedList); 95 | 96 | return FinalPaging; 97 | } 98 | 99 | //If youre paging say 30,000 rows and you know the processors of the users will be slow you can ASync thread both of these to allow the UI to update after they finish and prevent a hang. 100 | 101 | /// 102 | /// Internal Method: Performs the Work of converting the Passed in list to a DataTable 103 | /// 104 | /// 105 | /// 106 | /// DataTable 107 | private DataTable PagedTable(IList SourceList) 108 | { 109 | Type columnType = typeof(T); 110 | DataTable TableToReturn = new DataTable(); 111 | 112 | foreach (var Column in columnType.GetProperties()) 113 | { 114 | TableToReturn.Columns.Add(Column.Name, Column.PropertyType); 115 | } 116 | 117 | foreach (object item in SourceList) 118 | { 119 | DataRow ReturnTableRow = TableToReturn.NewRow(); 120 | foreach (var Column in columnType.GetProperties()) 121 | { 122 | ReturnTableRow[Column.Name] = Column.GetValue(item); 123 | } 124 | TableToReturn.Rows.Add(ReturnTableRow); 125 | } 126 | return TableToReturn; 127 | } 128 | } 129 | } 130 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | ## Ignore Visual Studio temporary files, build results, and 2 | ## files generated by popular Visual Studio add-ons. 3 | 4 | # User-specific files 5 | *.suo 6 | *.user 7 | *.userosscache 8 | *.sln.docstates 9 | 10 | # User-specific files (MonoDevelop/Xamarin Studio) 11 | *.userprefs 12 | 13 | # Build results 14 | [Dd]ebug/ 15 | [Dd]ebugPublic/ 16 | [Rr]elease/ 17 | [Rr]eleases/ 18 | x64/ 19 | x86/ 20 | bld/ 21 | [Bb]in/ 22 | [Oo]bj/ 23 | [Ll]og/ 24 | 25 | # Visual Studio 2015 cache/options directory 26 | .vs/ 27 | # Uncomment if you have tasks that create the project's static files in wwwroot 28 | #wwwroot/ 29 | 30 | # MSTest test Results 31 | [Tt]est[Rr]esult*/ 32 | [Bb]uild[Ll]og.* 33 | 34 | # NUNIT 35 | *.VisualState.xml 36 | TestResult.xml 37 | 38 | # Build Results of an ATL Project 39 | [Dd]ebugPS/ 40 | [Rr]eleasePS/ 41 | dlldata.c 42 | 43 | # DNX 44 | project.lock.json 45 | project.fragment.lock.json 46 | artifacts/ 47 | 48 | *_i.c 49 | *_p.c 50 | *_i.h 51 | *.ilk 52 | *.meta 53 | *.obj 54 | *.pch 55 | *.pdb 56 | *.pgc 57 | *.pgd 58 | *.rsp 59 | *.sbr 60 | *.tlb 61 | *.tli 62 | *.tlh 63 | *.tmp 64 | *.tmp_proj 65 | *.log 66 | *.vspscc 67 | *.vssscc 68 | .builds 69 | *.pidb 70 | *.svclog 71 | *.scc 72 | 73 | # Chutzpah Test files 74 | _Chutzpah* 75 | 76 | # Visual C++ cache files 77 | ipch/ 78 | *.aps 79 | *.ncb 80 | *.opendb 81 | *.opensdf 82 | *.sdf 83 | *.cachefile 84 | *.VC.db 85 | *.VC.VC.opendb 86 | 87 | # Visual Studio profiler 88 | *.psess 89 | *.vsp 90 | *.vspx 91 | *.sap 92 | 93 | # TFS 2012 Local Workspace 94 | $tf/ 95 | 96 | # Guidance Automation Toolkit 97 | *.gpState 98 | 99 | # ReSharper is a .NET coding add-in 100 | _ReSharper*/ 101 | *.[Rr]e[Ss]harper 102 | *.DotSettings.user 103 | 104 | # JustCode is a .NET coding add-in 105 | .JustCode 106 | 107 | # TeamCity is a build add-in 108 | _TeamCity* 109 | 110 | # DotCover is a Code Coverage Tool 111 | *.dotCover 112 | 113 | # NCrunch 114 | _NCrunch_* 115 | .*crunch*.local.xml 116 | nCrunchTemp_* 117 | 118 | # MightyMoose 119 | *.mm.* 120 | AutoTest.Net/ 121 | 122 | # Web workbench (sass) 123 | .sass-cache/ 124 | 125 | # Installshield output folder 126 | [Ee]xpress/ 127 | 128 | # DocProject is a documentation generator add-in 129 | DocProject/buildhelp/ 130 | DocProject/Help/*.HxT 131 | DocProject/Help/*.HxC 132 | DocProject/Help/*.hhc 133 | DocProject/Help/*.hhk 134 | DocProject/Help/*.hhp 135 | DocProject/Help/Html2 136 | DocProject/Help/html 137 | 138 | # Click-Once directory 139 | publish/ 140 | 141 | # Publish Web Output 142 | *.[Pp]ublish.xml 143 | *.azurePubxml 144 | # TODO: Comment the next line if you want to checkin your web deploy settings 145 | # but database connection strings (with potential passwords) will be unencrypted 146 | #*.pubxml 147 | *.publishproj 148 | 149 | # Microsoft Azure Web App publish settings. Comment the next line if you want to 150 | # checkin your Azure Web App publish settings, but sensitive information contained 151 | # in these scripts will be unencrypted 152 | PublishScripts/ 153 | 154 | # NuGet Packages 155 | *.nupkg 156 | # The packages folder can be ignored because of Package Restore 157 | **/packages/* 158 | # except build/, which is used as an MSBuild target. 159 | !**/packages/build/ 160 | # Uncomment if necessary however generally it will be regenerated when needed 161 | #!**/packages/repositories.config 162 | # NuGet v3's project.json files produces more ignoreable files 163 | *.nuget.props 164 | *.nuget.targets 165 | 166 | # Microsoft Azure Build Output 167 | csx/ 168 | *.build.csdef 169 | 170 | # Microsoft Azure Emulator 171 | ecf/ 172 | rcf/ 173 | 174 | # Windows Store app package directories and files 175 | AppPackages/ 176 | BundleArtifacts/ 177 | Package.StoreAssociation.xml 178 | _pkginfo.txt 179 | 180 | # Visual Studio cache files 181 | # files ending in .cache can be ignored 182 | *.[Cc]ache 183 | # but keep track of directories ending in .cache 184 | !*.[Cc]ache/ 185 | 186 | # Others 187 | ClientBin/ 188 | ~$* 189 | *~ 190 | *.dbmdl 191 | *.dbproj.schemaview 192 | *.jfm 193 | *.pfx 194 | *.publishsettings 195 | node_modules/ 196 | orleans.codegen.cs 197 | 198 | # Since there are multiple workflows, uncomment next line to ignore bower_components 199 | # (https://github.com/github/gitignore/pull/1529#issuecomment-104372622) 200 | #bower_components/ 201 | 202 | # RIA/Silverlight projects 203 | Generated_Code/ 204 | 205 | # Backup & report files from converting an old project file 206 | # to a newer Visual Studio version. Backup files are not needed, 207 | # because we have git ;-) 208 | _UpgradeReport_Files/ 209 | Backup*/ 210 | UpgradeLog*.XML 211 | UpgradeLog*.htm 212 | 213 | # SQL Server files 214 | *.mdf 215 | *.ldf 216 | 217 | # Business Intelligence projects 218 | *.rdl.data 219 | *.bim.layout 220 | *.bim_*.settings 221 | 222 | # Microsoft Fakes 223 | FakesAssemblies/ 224 | 225 | # GhostDoc plugin setting file 226 | *.GhostDoc.xml 227 | 228 | # Node.js Tools for Visual Studio 229 | .ntvs_analysis.dat 230 | 231 | # Visual Studio 6 build log 232 | *.plg 233 | 234 | # Visual Studio 6 workspace options file 235 | *.opt 236 | 237 | # Visual Studio LightSwitch build output 238 | **/*.HTMLClient/GeneratedArtifacts 239 | **/*.DesktopClient/GeneratedArtifacts 240 | **/*.DesktopClient/ModelManifest.xml 241 | **/*.Server/GeneratedArtifacts 242 | **/*.Server/ModelManifest.xml 243 | _Pvt_Extensions 244 | 245 | # Paket dependency manager 246 | .paket/paket.exe 247 | paket-files/ 248 | 249 | # FAKE - F# Make 250 | .fake/ 251 | 252 | # JetBrains Rider 253 | .idea/ 254 | *.sln.iml 255 | 256 | # CodeRush 257 | .cr/ 258 | 259 | # Python Tools for Visual Studio (PTVS) 260 | __pycache__/ 261 | *.pyc -------------------------------------------------------------------------------- /PagingWPFDataGrid/Properties/Resources.resx: -------------------------------------------------------------------------------- 1 | 2 | 3 | 62 | 63 | 64 | 65 | 66 | 67 | 68 | 69 | 70 | 71 | 72 | 73 | 74 | 75 | 76 | 77 | 78 | 79 | 80 | 81 | 82 | 83 | 84 | 85 | 86 | 87 | 88 | 89 | 90 | 91 | 92 | 93 | 94 | 95 | 96 | 97 | 98 | 99 | 100 | 101 | 102 | 103 | 104 | 105 | 106 | text/microsoft-resx 107 | 108 | 109 | 2.0 110 | 111 | 112 | System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 113 | 114 | 115 | System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 116 | 117 | --------------------------------------------------------------------------------