jQuery UI Dialog enterle tetiklemek

Aralık 2nd, 2011

jQuery UI dialog da bir formu doldurup entere bastigimizda genelde hic bir tepki almayiz. Oysaki cogumuz giris bilgilerini doldurduktan sonra entere basmayi aliskinlik haline getirmisiz. Jquery Ui dialog ile bir login formu gösteriyorsaniz sayfanizda ve kullanicilariniza bir iyilik yapmak istiyorsaniz, asagidaki kodu programiniza eklemeyi unutmayiniz.

$('#dialog').live('keyup', function(e){
	  	if (e.keyCode == 13) {
	    	$(':button:contains("Einloggen")').click();
	  	}
	});

Einloggen yazan yere Dialog da buttona verdiginiz adi giriniz.
dialog da gösterdiginiz div in id si

Kategoriler: Javascript/Ajax/Jquery

Etiketler:, Yorum Yapılmamış

Eclipse 3.7 Android ADT kurulum hatasi

Kasım 9th, 2011

Eclipse 3.7 de Android ADT kurarken söyle bir hata ile karsilasanlar varsa.

Cannot complete the install because one or more required items could not be found.
Software being installed: Android Development Tools 15.0.0.v201110251216-213216 (com.android.ide.eclipse.adt.feature.group 15.0.0.v201110251216-213216)
Missing requirement: Android Development Tools 15.0.0.v201110251216-213216 (com.android.ide.eclipse.adt.feature.group 15.0.0.v201110251216-213216) requires ‘org.eclipse.wst.sse.core 0.0.0′ but it could not be found

http://download.eclipse.org/releases/indigo adresini Help -> Install New Software -> Add eklemeleri ve kurulumu yeniden denemeleri gerekiyor.
Bende sorun bu sekilde cözüldü.

kolay gelsin

Kategoriler: Android, Java

Etiketler:, Yorum Yapılmamış

Silverstripe yeni sayfa tipleri

Kasım 1st, 2011

Silverstripe’i ilk kurdugumuzda bazi standard sayfa türleri ile gelir.
Sistemimizin gereksinime göre degisik sayfa türleri üretmemiz gereklidir.
Bugünki yazimizda SS’de baska bir sayfa türü nasil olusturulur ona bakacagiz.

Önce SS ile default olarak gelen sayfa türlerini taniyalim:

  • Page:en temel sayfa türüdür.Ilerki yazilarda üretecegimiz tüm sayfalar bu türden olacaktir
  • ErrorPage:Hata oldugunda gösterilicek olan sayfa. Degisik hatalara degisik sayfalar üretile bilinir. mesela 404 bulunamadi ile 403 erisim engellendi sayfalari degisik görüne bilinir
  • RedirectorPage: Baska bir sayfaya veya Websitesine yönlendirmek icin kullanilir
  • VirtualPage: baska bir sayfanin icerigini kullanir. Redirector sayfasindan bunu ayiran, sadece sitemiz icindeki sitelerde kullanilir ve icerigini kopyalar.

Kendi Sayfa türümüzü olusturalim
/mysite/code klasörü icinde Baslik, tarih, resim ve icerik eklene bilen bir sayfa türü üretelim, adinida ArticlePage koyalim.

/mysite/code/ArticlePage.php

<?php

class ArticlePage extends Page { // Model
    static $db = array(
       'Date' => 'Date',
    );
    public static $has_one = array(
        'Picture' => 'Image',
    );
    function getCMSFields() {
       $fields = parent::getCMSFields();

       $fields->addFieldToTab('Root.Content.Main', new DateField('Date'), 'Content');
       $fields->addFieldToTab("Root.Content.Main", new ImageField('Picture'));

       return $fields;
    }
}
/* controller */
class ArticlePage_Controller extends Page_Controller {
}

?>

Silverstripe MVC tasarim kalibini kullanmaktadir.
Silverstripe de olusturdugumuz her sayfa Model ve Controller kismini barindirmaktadir.
Her sayfa Page sayfasindan extend etmelidir.

static $db = array('Date' => 'Date',);

db degiskeninin özel bir islevi vardir, veritabani alanlari tanimlamak icin kullanilir.
Örnegimizde tarihi kaydetmek icin Date tipinde bir alan adi tanimladik.

has_one degiskeni her ArticlePage sayfamiza bir resim eklemesini söylüyor.
Bu baglantilara daha sonraki bir yazimizda daha detayli bakacagiz.

Gerekli alanlari tanimladikdan sonra bunlari Admin e eklememiz gerekiyor.
GetCMSFields ile bu isi yapa biliriz.

View kismina bakalim.
theme dosyamizda ArticlePage.ss adinda bir dosya olusturalim.
/themes/blackcandy/templates/Layout/ArticlePages.ss


    <div>
        <h1>$Title</h1>
        <div>Date : $Date.nice</div>
        <div>$Picture</div>
        $Content
        $Form
    </div>

Model, view ve Controlleri tamamladikdan sonra adres satirina /dev/build/?flush=all yazip degisiklikleri kaydedelim.
Simdi Admin de yeni bir sayfa üretmek istedigimizde ArticlePage sayfamizi sece biliriz.

Kategoriler: Cms, PHP, Silverstripe

Etiketler:, , 1 Yorum

Silverstripe snippetler

Eylül 4th, 2011

Adres satirina eklenenler
Template in olusturdugu kodu görmek icin

?isDev=1&showtemplate=1

önbellegi temizlememe

?flush=all

kodu ve db yi senkronlamak icin önemli (http://localhost/dev/build seklinde olmali)

/dev/build

Tüm sayfalari birden yayinlamak

/admin/publishall/

veritabanini olusturur ama kayitlari eklemez

/dev/build?dont_populate=1

config dosyasindaki degere aldirilmadan, Test moduna gec

?isTest=1

tüm queryleri göstermek icin:

?showqueries=1

tüm insert ve updateleri gösterir ama calistirmaz

?previewwrite=1

performance icin

?debug_memory=1
?debug_profile=1
?debug_profile=1&profile_trace=1

diger

?debugmanifest=1
?debugmethods=1
?debugfailover=1
?debug_request=1
?debug=1

mysite/_config.php icine eklenenler
development moda gecmek icin (standard live mod)

Director::set_environment_type('dev'); 

(daha fazla…)

Kategoriler: Cms, PHP, Silverstripe

Etiketler:, , Yorum Yapılmamış

MSSQL snippetler

Temmuz 15th, 2011

Konuyu Mssql Snippet konusuna cevirmeye karar verdim.
Aradigimda kolaylikla bulabilmek icin bu satirlari ekliyorum.
Mssql de bir DB nin tüm indexlerini görüntülemek icin bu satirlari kullana bilirsiniz.

SELECT i.object_id, i.name, o.name
 FROM sys.indexes as i, sys.objects as o
 WHERE i.name not like 'queue%'
 and i.object_id = o.object_id
 AND o.name NOT like 'sys%'

db de eski programdan tarihleri ve zamanlari ayni olan siparisler vardi buda benim bir queryimi bozuyordu, ayni olan zamanlarin birine 3 saniye fazladan ekledim.

update orders set
or_datetime=DATEADD(ss,03,or_datetime)
where or_id in (select MAX(or_id) from orders as x
		where or_datetime in(select or_datetime
		   from orders where x.or_person_id=or_person_id
		   group by or_datetime having count(*) > 1)
               group by or_person_id
)

devami gelecek…

Kategoriler: Veritabani

Etiketler: Yorum Yapılmamış

C# .COM bileseniyle Excel export

Temmuz 14th, 2011

Bugün son günlerde urastigim birseyi sizlerle paylasmak istiyorum.
Datagridview dan Excel e veri export etmem gerekiyordu, bunun icin hemen bir Library aradim, FF de arkadasin birisi sagolsun yardimci olmaya calisti.
Ben vermis oldugu linkten NPOI kütüphanesini kesfettim ve kullanmaya basladim.
Ama Iki gün önce farkettimki 10 000 satir lik bir export haddinden fazla (>10 dk) sürüyordu. Halbuki yapilacak olan export nice 10 000 leri yapa bilmeli.
Devam arastirdim bizim servere disaridan erisim kapali sadece Citrix icinden calisiyor ve üstünde Excel bulunuyordu, bende .COM bilesenlerini kullanmaya karar verdim.
Yeni bir test yapip en basit haliyle söyle bir kod olusturdum.

private void btn_export_Click(object sender, EventArgs e) {
    Excel.Application xlApp;
    Excel.Workbook xlWorkBook;
    Excel.Worksheet xlWorkSheet;
    object misValue = System.Reflection.Missing.Value;

    xlApp = new Excel.Application();
    xlApp.ScreenUpdating = false;
    xlApp.Calculation = Excel.XlCalculation.xlCalculationManual;
    xlWorkBook = xlApp.Workbooks.Add(misValue);
    xlWorkSheet = (Excel.Worksheet)xlWorkBook.Worksheets.get_Item(1);
    int ix = 0;
    int j = 0;
    //datagridview un baslik sütunünü ekliyelim
    for (int x = 0; x < dgv_search_result.Columns.Count; x++)
    {
        xlWorkSheet.Cells[1, x + 1] = dgv_search_result.Columns[x].HeaderText;
    }
    //basliklari kalin yazalim ve yaziyi ortaliyalim
    xlWorkSheet.get_Range("A1", "T1").Font.Bold = true;
    xlWorkSheet.get_Range("A1", "T1").VerticalAlignment = Excel.XlVAlign.xlVAlignCenter;
    //ardindan Datagridview daki satirlari excel dosyamiza yazalim
    for (ix = 1; ix <= rowcount; ix++) {
       for (j = 0; j <= dgv_search_result.ColumnCount - 1; j++){
          DataGridViewCell cell = dgv_search_result[j, ix - 1];
          //10. sutünü Text olarak formatliyalim
          if(j==10)
             xlWorkSheet.Cells[ix + 1, j + 1].NumberFormat = "@";
          xlWorkSheet.Cells[ix + 1, j + 1] = cell.Value;
         }
     }

     //kayit edelim
      xlWorkBook.SaveAs(extraction_export.FileName, Excel.XlFileFormat.xlWorkbookNormal, misValue, misValue, misValue, misValue, Excel.XlSaveAsAccessMode.xlExclusive, misValue, misValue, misValue, misValue, misValue);
      xlWorkBook.Close(true, misValue, misValue);
       xlApp.Quit();
     //objeleri yok edelim
      releaseObject(xlWorkSheet);
      releaseObject(xlWorkBook);
      releaseObject(xlApp);
}
private void releaseObject(object obj){
   try
   {
      System.Runtime.InteropServices.Marshal.ReleaseComObject(obj);
      obj = null;
   }
   catch (Exception ex)
   {
       obj = null;
       MessageBox.Show("Hata olustu " + ex.ToString());
   }
   finally
   {
        GC.Collect();
   }
 }

(daha fazla…)

Kategoriler: C#

Etiketler: 2 Yorum

Silverstripe

Temmuz 12th, 2011

COktandir kullanmaya vakit bulamadigim, ama sonunda kullandigim acik kaynakli bir CMS/Framework den bahsetmek istiyorum.
Simdiye kadar kullandigim CMS ler arasinda bir PHP cinin kullana bilecegi en iyi CMS diye bilirim.

Silverstripe (SS) alt yapisinda yine SS in kurucularinin yazmis olduklari Sapphire Framework kullanilmakda.

SS icin bircok eklenti mevcut bunlara silverstripe.org sitesinden baka bilirsiniz.

SUana kadar tespit ettiklerim:

  • güclü nesne yönelimli yapisi
  • MVC-Pattern
  • Scaffolding
  • kolay genisletilebilirlik
  • kullanim kolayligi
  • eklentiler

.. vs bu liste uzar gider php de yeni bir CMS ariyan varsa demo icin buraya baka bilir: Silverstripe Demo

Bu arada bir günde Theming ile birlikde bir site olusturdum gecen hafta.
Silverstripe 2.4 Module Extension, Themes and Widgets kitabini okumaya basladim bundan sonra silverstripe hakkinda daha cok seyler yazacagim insallah.

Kategoriler: Cms, PHP, Silverstripe

Etiketler:, , 2 Yorum

Zend ViewHelper ve birden cok Metot barindirma

Mart 29th, 2011

View Scriptlerde komplex fonksiyonlari bircok kez calistirmak gerekiyorsa, bildigimiz gibi bunu Zend Framework ün bize sunmus oldugu View Helperler ile gerceklestire biliriz.
Bu yazimizda View Helperde birden cok Metodu nasil barindirirz ona bakalim.
Helper dedigimiz aslinda basit bir Sinif.
Diyelimki “String” adinda bir helper olusturmak istiyoruz.
Bu string helperi bize string adinda bir string geri versin istiyoruz.
Zend Studio nun varsayilan sablonunda helperler /application/views/helpers klasörü altinda kayit edile bilinir.
Bu klasörün icinde String.php diye bir dosya olusturalim.
Ve icine sunu kaydedelim
(daha fazla…)

Kategoriler: PHP, Zend Framework

Etiketler:, Yorum Yapılmamış

MSSQL birden fazla icerik eklemek

Mart 24th, 2011

Yazimizin anahtar kelimesi Table Valued Parameters (Tablo degerli parametreler).
MSSQL 2008 Serveri ile birlikte gelen yeniliklerden birtanesi.
Ben Stored Procedure ile gecici Tablo veya ek kod yazmadan kolayca nasil coklu kayit göndere biliriz onu gösterecegim.

Bir müsteri tablomuz oldugunu varsayalim

create table Musteri
(
    ID    	int not null primary key identity(1,1),
    Isim 	varchar(50) not null,
    Sehir	varchar(50) null,
    Tel		varchar(10) null,
)

2008 den önceki versiyonlarda böyle bir procedure u kac icerik ekliyorsak okadar calistirmamiz gerekiyordu.
TVP ile nasil yapiyoruz ona bakalim.

Veritabanimizda yeni bir Table User Defined Type olusturalim.

create type MusteriTableType as table
(
    Isim	varchar(50),
    Sehir        varchar(50),
    Tel       varchar(10)
)

ardindan stored procedure umuzu hazirliyalim.

create procedure MusteriCokluInsert
(
    @Okuvar MusteriTableType readonly
)
as
    insert
    into   Customers (Isim, Sehir, Tel)
    select Name, City, Phone
    from   @okuvar;

Simdi C# Programimizda bir DataTable olusturalim

DataTable MusteriTable = new DataTable();
MusteriTable.Columns.Add("Isim", typeof(string));
MusteriTable.Columns.Add("Sehir", typeof(string));
MusteriTable.Columns.Add("Tel", typeof(string));

birkac degerler atiyalim

MusteriTable.Rows.Add("Kadir", "Sakarya", "123");
MusteriTable.Rows.Add("Ahmetr", "Istanbul", "567");
MusteriTable.Rows.Add("Musti", "Bodrum", "789");

ve son olarak C# programimizdan stored procedurumuzu calistiralim

using (SqlConnection conn = new SqlConnection("..."))
{
  SqlCommand cmd = conn.CreateCommand();
  cmd.CommandType = System.Data.CommandType.StoredProcedure;
  cmd.CommandText = "dbo.MusteriCokluInsert";
  SqlParameter param = cmd.Parameters.AddWithValue("@Okuvar", MusteriTable);
  conn.Open();
  cmd.ExecuteNonQuery();

}

Simdi Müsteri tablomuza baktigimizda icerikler eklenmis olacaktir.
hepsi bukadar kolay gelsin.

Kategoriler: C#, Veritabani

Etiketler:, Yorum Yapılmamış

XenServer de Windows kurulumu

Ocak 24th, 2011

bir önceki yazimizda Xenserver e Windows yüklemek icin depo nasil olustururuz ona baktik.
Simdi ise Windows kurarken dikkat edilmesi gereken bir kac önemli nokta var onlara bakalim.

-VM olustururken en son adimda “Start VM automatically” secmiyoruz
-XenServerimize root ile baglanip

xe vm-list

calistiriyoruz ve suna benzer bir cikti aliyoruz

xe vm-list

uuid satirinda yazan numara birdahaki adimda bize lazim olan id.
son olarak su komutu calistiralim

xe vm-param-set uuid=<UUID> platform:viridian=false

uuid yazan yere yukardaki resimdeki uuid yi yaziyoruz.

Simdi Vm makinanizi calistira bilirsiniz.

Xp kurarken vm olustururken template olarak windows xp sp3 ü sectim ama windows 7 kurarken “other install media” secilmesi gerektigini bir kac forumda okudum.
Windows 7 kurarken takili kaliyorsa template i degistirip yeniden deneyiniz.

Kategoriler: Linux

Etiketler:, Yorum Yapılmamış

Feed

http://www.skorp.eu /