Ana içeriğe atla

Devexpress ASPxGridView - Layout Kaydetme, Uygulama


Merhaba, bu yazımda Devexpress ASPxGridView nesnesi için dinamik filtreleme işlemlerinin nasıl yapılabileceğini anlatmaya çalışacağım.ASPxGridView ile listeleme yaptığımız çok kullanıcılı bir ekran düşünün. Bu ekran bir raporlama, satış analizi vs. bilgilerini içersin.

Mesela satış ekranı için satılan ürün,fiyat ve stok bilgilerini listelediğimizi varsayalım. bir kullanıcı için stok bilgileri gereksiz iken diğer bir kullanıcı fiyat bilgilerini görmek istemeyebilir. N sayıda varyason olabilir.Sonuçta her kullanıcı kendi ASPxGridView nesnesini istediği şekilde düzenleyebilir(Gruplama,Kolon sıralaması, kolonları gizleme vs.). Standart ortamda ASPxGridview üzerindeki bu layout düzenlemelerini sayfaya her girdiklerinde yapmak zorundalar.Yapacağımız uygulama ile bu işlemin yanlızca bir kez yapılmasını sağlayacak, kullanıcıya özel grid layout tasarımı oluşturmuş olacağız.Ben en basit şekilde anlatmaya çalışacağım.

Haydi başlayalım;

1. Önce SQL Server tarafında TBLGridLayouts isimli bir tablo oluşturuyorum.
  • Id (int) otomatik artan, not null
  • SayfaId (int),not null
  • KullaniciAdi (nvarchar)
  • LayoutData (nvarchar(MAX))


2. Boş bir WEB Forms sayfası açalım. Sayfaya aşağıdaki nesneleri ekleyelim;
  • Bir adet ASPxGridview,
  • Bir adet SqlDataSource,
  • 2 adet ASPxButton (Görünümü kaydet,  Görünümü getir)
ASPxGridView nesnenizi SqlDatasource ile herhangi bir veri kaynağına bağlayıp listelemeyi sağlayın. ASPxGridview için bu seçeneği uygulayın;




Evet, tasarım işlemi buraya kadar. şimdi iki butondan birisi geçerli görünümü tablomuza kaydederken, diğeri de görünümü sayfaya getirmemizi sağlayacak. dilerseniz geri getirme işlemini load olayında da yapabilirsiniz.



Layout kaydetmek için;
protected void btnGorunumKaydet_Click(object sender, EventArgs e)
    {
        string qData = ASPxGridView1.SaveClientLayout();
        if (Session["KullaniciAdi"] != null) //kullanıcı adı boş değilse.
        {
            using (Veritabani vt = new Veritabani())
            {
                int qCount = vt.SorgulaTekDeger("SELECT COUNT(Id) FROM TBLGridLayouts WITH (NOLOCK) WHERE (SayfaId=@SayfaId) AND (KullaniciAdi=@KullaniciAdi)", new string[] { "@SayfaId", "@KullaniciAdi" }, new object[] { Request.QueryString["SayfaId"], Session["KullaniciAdi"] });

                if (qCount > 0)
                {
                    vt.Calistir("DELETE FROM TBLGridLayouts WHERE (SayfaId=@SayfaId) AND (KullaniciAdi=@KullaniciAdi)", new string[] { "@SayfaId", "@KullaniciAdi" }, new object[] { Request.QueryString["SayfaId"], Session["KullaniciAdi"] });
                }

                vt.Calistir("INSERT INTO TBLGridLayouts (SayfaId,KullaniciAdi,LayoutData) VALUES(@SayfaId,@KullaniciAdi,@LayoutData)",
                    new string[] { "@SayfaId", "@KullaniciAdi", "@LayoutData" }, new object[] { Request.QueryString["SayfaId"], Session["KullaniciAdi"], qData });
            }
        }
    }

Kaydedilen Layout bilgisini ASPxGridView nesnesine yüklemek için ;
protected void btnGorunumGetir_Click(object sender, EventArgs e)
    {
        using (Veritabani vt = new Veritabani())
        {
            string qData = vt.SorgulaTekDeger("SELECT LayoutData FROM TBLGridLayouts WITH (NOLOCK) WHERE  (SayfaId=@SayfaId) AND (KullaniciAdi=@KullaniciAdi)", new string[] { "@SayfaId", "@KullaniciAdi" }, new object[] { Request.QueryString["SayfaId"], Session["KullaniciAdi"] });
            ASPxGridView1.LoadClientLayout(qData);
        }
    }

işte hepsi bu kadar. Sayfa Id sini en basit anlamda QueryString ile alabilirsiniz












Bu blogdaki popüler yayınlar

ASP.NET Sayfalar arası veri taşıma işlemleri

merhaba;

bu yazımda sizlere asp.net üzerinde sayfalar arasında veri taşıma işlemlerinden bahsetmek istiyorum.hepimizin bildiği gibi uygulamarımızda sayfalarımız arası haberleşmeler büyük önem arzetmektedir.bazı sayfalarda bazı işlemlerin yerine getirilebilmesi için diğer sayfalardan gelecek verilere ihtiyaç duyulabilir(GET).ASP.NET üzerinde veri taşıma işlemleri aşağıdaki şekillerde yapılabilir.

1-)QueryString : en yaygın ve basit kullanıma sahip olanıdır.istenilen verileri sayfayı post ettiğiniz zaman yönlendirildiğiniz sayfaya URL üzerinden taşır.

Kullanımı :

a sayfasından b sayfasına isim taşıyalım.

a sayfasında linkinizi şu şekilde değiştirirseniz:
Response.Redirect("gidileceksayfa.aspx?isim=can");
Tarayıcınızın URL kısmına baktığınızda:

www.siteadi.com/b.aspx?isim=canolarak görürsünüz.a sayfasından veri aktarımı tamamlanmıştır.bundan sonraki adım b sayfasından gelen veriyi almaktan ibarettir.o da şu şekilde yapılır:

b sayfasında "isim" adında bir değişken tanıml…

Devexpress Türkçe Dil Paketi

Merhaba,

Devexpress kontrollerinizi türkçe veya  başka bir dil ile kullanmak istiyorsanız Localized assembly leri indirmeniz gerekmektedir.Daha önceleri bu çok zorlu bir süreç oluyordu.internetteki uzun araştırmalar,yanlış veya eksik çeviriler vs. bir sürü problem ile karışılaşıyorduk.nihayet beklediğimiz gibi developer express firması bu soruna el attı ve güzel bir çözüm getirdi.artık https://localization.devexpress.com/ adresi üzerinden devexpress türkçe paketlerini en güncel ve doğru şekliyle hemen indirip kullanabilirsiniz.dil desteğini uygulayabilmek için exe nin bulunduğu path deki dll dosyalarını değiştirmeniz yeterli olacaktır.eski dll dosyaları yerine yeni dil paketindeki dosyaları yapıştırın ve uygulamanızı başlatın.bu hizmeti kullanabilmek için resmi devexpress sitesi olan http://devexpress.com/ 'a üye olmanız gerekmektedir.işlem tamamlandığında indirme linki e-posta adresinize gelmektedir.dil pakedini indirirken talep ettiğiniz paketversiyonun kullandığınız devexpress…

PAYTR SANAL POS ASP.NET C# Entegrasyonu

merhaba, bu makalede sizlere PAYTR Sanal pos yapısını .NET üzerinde nasıl çalıştıracağımız ile ilgili bilgi aktarmaya çalışacağım. Ücretsiz başlangıç sağlaması ve sabit ödeme almaması sebebiyle düşük bütçeli e-ticaret yapmak isteyen kişilerin tercih ettiği PAYTR Sanal pos entegrasyonu temelde PHP üzerine kurulmuş. Dolayısıyla .net ile e-ticaret yazmaktaysanız bu sizi bir hayli zorluyor zira firma ile birçok görüşme yapmama rağmen sağlıklı bir .net örneklemesi bulamadım. Baktım olacak gibi değil, sonunda oturdum kendi entegrasyonumu kendim yazdım :). aşağıda detaylı olarak bulabilirsiniz.

//using satırlarımızı ekleyelim; using Newtonsoft.Json.Linq; using System; using System.Collections.Generic; using System.Collections.Specialized; using System.Data; using System.Linq; using System.Net; using System.Security.Cryptography; using System.Text; using System.Web; using System.Web.Script.Serialization; using System.Web.UI; using System.Web.UI.WebControls; //aşağıdaki sabit PAYTR Fonksiyonla…