Blog listelemesini değiştirmek için "Görüntülenebilir Sorugular"ın Sonuç Görüntüleme Şablonu alanını "Tablo" değil "Özel kart" seçmemiz ve "Kart görünümü şablon sınıfı" alanında kendi belirteceğimiz "ResultsViewer" dan türeyen bir görünümü bildirmemiz gerekiyor.
Bunun için öncelikle ResultsViewer dan türeyen BlogViewer sınıfını oluşturuyoruz.
BlogViewer sınıfı bir görünüm olduğu için App\Views isim uzayı altına oluşturulmalıdır.
getTemplateFile fonksiyonu soyut olan ResultsViewer sınıfından kalıtıldığı için yeniden yazılmalıdır. Çevrilen değer bu görünümün kullanacağı twig dosyasının adıdır. Bu dosya tema içerisinde templates/views altında bulunmalıdır.
Görüntülenebilir sorguda ise şu ayarı yapıyoruz:
Tema dizininde templates/views altında blog-viewer.twig dosyası oluşturuyoruz.
Bu aşamada /blog sayfasına baktığımızda sayfanın içeriğinin boş olduğunu göreceğiz. Bunun nedeni BlogViewer tema dosyasına hiçbirşey yazmamış olmamızdır.
CoreDB içerisinde bulunan Table (Tablo) görünümü de ResultsViewer'dan türemektedir. Bunun için hazırlayacağımız twig dosyası için Table görünümünün kullandığı table.twig dosyasından kopya çekebiliriz.
table.twig dosyası aşağıdaki gibidir.
Twig tarafında
İstenilen değişkenler kullanılıp istenilenler kullanılmayabilir.
Şablon olarak başlık kısımlarının kullanılmadığı durumda aşağıdaki görünüm şablonunun kullanılması tavsiye edilir.
Blog kartları için kullanacağımız HTML ve Bootstap şablonunu belirlemek amacıyla Bootstrap Cards sayfasına bakılabilir.
Basitçe şu kart yapısını kullanırsak:
<div class="card m-2">
<div class="card-body">
<h5 class="card-title">Card title</h5>
<p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
<a href="#" class="btn btn-primary">Go somewhere</a>
</div>
</div>Hazırlayacağımız twig dosyası aşağıdaki gibi olmalıdır:
Burada body alnı twig ya da view üzerinde tanımlanacak php metodları ile filtrelenebilir, özeti çıkarılabilir.
Bu aşamada blog sayfası aşağıdaki gibi görüntülenecektir: