Menfilter Tabel menggunakan methode Yii::app()->createUrl(.....)

Kamis, 24 Oktober 2013

(oleh : Badiyanto)

Aplikasi web untuk menampikan informasi tertentu ada yang dengan cara mengklik salah satu rekaman yang ditampilkan dalam tabel. Jika rekaman tersebut di Link dan mengirimkan nilai kunci, maka hasilnya akan ditampilkan sesuai dengan nilai kunci yang sama saja. Contoh kasus ada tabel daftar pengarang, ketika diklik akan menampilkan buku yang dikarangn saja

Ketikan baris peertama di klik maka akan menampilkan

Untuk itu yang dilakukan dengan mengubah file /views/tblPengarang/index.php

<?php
/* @var $this TblPengarangController */
/* @var $model TblPengarang */

$this->breadcrumbs=array(
    'Tbl Pengarangs'=>array('index'),
    'Manage',
);

$this->menu=array(
    array('label'=>'List TblPengarang', 'url'=>array('index')),
    array('label'=>'Create TblPengarang', 'url'=>array('create')),
);

Yii::app()->clientScript->registerScript('search', "
$('.search-button').click(function(){
    $('.search-form').toggle();
    return false;
});
$('.search-form form').submit(function(){
    $.fn.yiiGridView.update('tbl-pengarang-grid', {
        data: $(this).serialize()
    });
    return false;
});
");
?>

<h1>Manage Tbl Pengarangs</h1>

<p>
You may optionally enter a comparison operator (<b>&lt;</b>, <b>&lt;=</b>, <b>&gt;</b>, <b>&gt;=</b>, <b>&lt;&gt;</b>
or <b>=</b>) at the beginning of each of your search values to specify how the comparison should be done.
</p>

<?php echo CHtml::link('Advanced Search','#',array('class'=>'search-button')); ?>
<div class="search-form" style="display:none">
<?php $this->renderPartial('_search',array(
    'model'=>$model,
)); ?>
</div><!-- search-form -->

<?php $this->widget('zii.widgets.grid.CGridView', array(
    'id'=>'tbl-pengarang-grid',
    'dataProvider'=>$model->search(),
    'filter'=>$model,
    'columns'=>array(
        array(
            'name'=>'id',
            'type'=>'raw',
            'value'=>'CHtml::link(CHtml::encode($data->id),$data->bukuUrl)',
            'htmlOptions'=>array('width'=>'3%'),
        ),
        array(
            'name'=>'nama_pengarang',
            'type'=>'raw',
            'value'=>'CHtml::link(CHtml::encode($data->nama_pengarang),$data->bukuUrl)',
            'htmlOptions'=>array('width'=>'50%'),
        ),
        'alamat',
        'jenin_kelamin',
    array(
            'class'=>'CButtonColumn',
        ),
    ),
)); ?>

Kemudian tambahan fungsi untuk mengarahkan link Url pada model/kelas TblPengarang.php

public function getBukuUrl()
    {
        return Yii::app()->createUrl('/tblBuku/daftarBuku2',array(
            'id'=>$this->id,
        ));
    }


perintah : Yii::app()->createUrl('/tblBuku/daftarBuku2(... ketika link diklik makan akan memanggil tampilan view daftarBuku2.php dan
array( 'id'=>$this->id,)) adalah menyertakan variabel $id/nilai kunci primer di tabel pengarang.

mengujinya dengan memanggil http://localhost/coba/index.php?r=tblPengarang/admin, kemudian untuk  File daftarBuku2.php sama dengan dan model TblBuku.php

Berita Lainnya

Showing 1-3 of 412 items.
Sri Redjeki, S....
Sri Redjeki, S.Si., M.Kom, Dosen STMIK AKAKOM berhasil lolos dalam program Research Dive : Artificial Intelligence and Machine Learning for Estimating Poverty Selasa, 24 Juli 2018

Kemiskinan masih menjadi masalah utama dan serius yang harus mendapat perhatian khusus pemerintah daerah dan pusat di Indonesia. Target pemerintah ... Selengkapnya

STMIK AKAKOM kembangkan ...
STMIK AKAKOM kembangkan pesantren programmer bersama Asosiasi Cloud Computing Indonesia Selasa, 24 Juli 2018

STMIK AKAKOM ikut berinisiasi dengan Asosiasi Cloud Computing Indonesia dan beberapa kampus di Jogja meluncurkan Program Nasional Pesantren Programmer ... Selengkapnya

Mahasiswa STMIK Akakom ...
Mahasiswa STMIK Akakom raih mendali emas di lomba Kejurkot Tarung Derajat Kota Yogjakarta 2018 Jumat, 13 Juli 2018

Mahasiswa STMIK AKAKOM Tak Henti Mengukir Prestasi Kali ini dari bidang olahraga, anggota UKM Tarung Derajat STMIK AKAKOM YOGYAKARTA berhasil ... Selengkapnya