- [SQLSERVER] Loại bỏ Restricted User trên database MSSQL
- [C#] Hướng dẫn tạo mã QRcode Style trên winform
- [C#] Hướng dẫn sử dụng temp mail service api trên winform
- [C#] Hướng dẫn tạo mã thanh toán VietQR Pay không sử dụng API trên winform
- [C#] Hướng Dẫn Tạo Windows Service Đơn Giản Bằng Topshelf
- [C#] Chia sẻ source code đọc dữ liệu từ Google Sheet trên winform
- [C#] Chia sẻ source code tạo mã QR MOMO đa năng Winform
- [C#] Chia sẻ source code phần mềm lên lịch tự động chạy ứng dụng Scheduler Task Winform
- [Phần mềm] Tải và cài đặt phần mềm Sublime Text 4180 full version
- [C#] Hướng dẫn download file từ Minio Server Winform
- [C#] Hướng dẫn đăng nhập zalo login sử dụng API v4 trên winform
- [SOFTWARE] Phần mềm gởi tin nhắn Zalo Marketing Pro giá rẻ mềm nhất thị trường
- [C#] Việt hóa Text Button trên MessageBox Dialog Winform
- [DEVEXPRESS] Chia sẻ code các tạo report in nhiều hóa đơn trên XtraReport C#
- [POWER AUTOMATE] Hướng dẫn gởi tin nhắn zalo từ file Excel - No code
- [C#] Chia sẻ code lock và unlock user trong domain Window
- [DEVEXPRESS] Vẽ Biểu Đồ Stock Chứng Khoán - Công Cụ Thiết Yếu Cho Nhà Đầu Tư trên Winform
- [C#] Hướng dẫn bảo mật ứng dụng 2FA (Multi-factor Authentication) trên Winform
- [C#] Hướng dẫn convert HTML code sang PDF File trên NetCore 7 Winform
- [C#] Hướng dẫn viết ứng dụng chat với Gemini AI Google Winform
[DEVEXPRESS] Hướng dẫn show Form chọn dữ liệu từ Form2 trả về Form1 trên C#
Xin chào các bạn, bài viết hôm nay mình tiếp tục hướng dẫn các bạn, cách tạo Form2 như hộp thoại dialog chọn thông tin Employee và trả về kết quả cho Form1 trên lập trình C# Winform.
[DEVEXPRESS] Get muli select value from Form Show Dialog Devexpress
Chi tiết các bạn có thể xem video Demo mình ở bên dưới:
Ở hình trên các bạn thấy, khi mình click vào button chọn Employee ở Form1.
Hệ thống sẽ hiển thị dữ liệu từ Form2 lên, và chúng ta sẽ chọn dữ liệu Employee, và khi bấm nút OK thì kết quả chọn sẻ trả về cho Form1.
Source code Form1.cs:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
namespace DemoGetValueFormDialog
{
public partial class Form1 : DevExpress.XtraEditors.XtraForm
{
public Form1()
{
InitializeComponent();
}
private void btnSelect_Click(object sender, EventArgs e)
{
var frm = new FrmSelectEmployee();
var dialogResult = frm.ShowDialog();
if (dialogResult == DialogResult.OK) {
var data = frm.listEmployeeSelectedReturn;
gridControl1.DataSource = data;
// show this to Gridview
}
}
private void simpleButton1_Click(object sender, EventArgs e)
{
const string cacheKey = "Employees";
var employees = FrmSelectEmployee.cache.Get(cacheKey) as List<Employee>;
var b = employees;
}
}
}
Source code Form2.cs
using DevExpress.XtraEditors;
using Newtonsoft.Json;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Net;
using System.Runtime.Caching;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
namespace DemoGetValueFormDialog
{
public partial class FrmSelectEmployee : DevExpress.XtraEditors.XtraForm
{
public List<Employee> listEmployeeSelectedReturn = new List<Employee>();
string URL_API = "https://raw.githubusercontent.com/dinhtona/api-mssql-dapper/main/db.json";
public FrmSelectEmployee()
{
InitializeComponent();
this.Load += FrmSelectEmployee_Load;
}
public static readonly MemoryCache cache = MemoryCache.Default;
public List<Employee> GetEmployees()
{
const string cacheKey = "Employees";
var employees = cache.Get(cacheKey) as List<Employee>;
if (employees == null)
{
employees = GetEmployeesFromAPI();
cache.Add(cacheKey, employees, DateTimeOffset.Now.AddMinutes(30));
}
return employees;
}
public List<Employee> GetEmployeesFromAPI() {
var dataEmployees = new WebClient().DownloadString(URL_API);
var listEmployee = JsonConvert.DeserializeObject<List<Employee>>(dataEmployees);
return listEmployee;
}
private void FrmSelectEmployee_Load(object sender, EventArgs e)
{
gridControl1.DataSource = GetEmployees();
}
private void btnOK_Click(object sender, EventArgs e)
{
var employeeSelected = gridView1.GetSelectedRows(); // this return rowHandle
if (employeeSelected.Length == 0) {
XtraMessageBox.Show("Please select an Employee.", "Message");
return;
}
// get list employee
foreach (var rowHandle in employeeSelected)
{
var employee = gridView1.GetRow(rowHandle) as Employee;
listEmployeeSelectedReturn.Add(employee);
}
DialogResult= DialogResult.OK; // return OK
this.Close();
}
private void btnClose_Click(object sender, EventArgs e)
{
DialogResult = DialogResult.Cancel;
this.Close();
}
}
}
Thanks for watching!