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:Javascript/Ajax/Jquery, Jquery
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:android, Java
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:Cms, PHP, Silverstripe
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:Cms, PHP, Silverstripe
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:MSSQL
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:C#
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:Cms, PHP, Silverstripe
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:PHP, Zend Framework
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:C#, MSSQL
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

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:Linux, Xen