Pada tulisan ini saya akan membuat series mengenai pemrograman dengan Yii Framework. Series ini akan disusun untuk membuat sebuah program sederhana yang memanfaatkan fitur-fitur umum yang sangat mungkin digunakan di banyak kasus. Tulisan ini akan menggunakan Basic Template Yii2 (yang menurut saya penggunaannya sedikit lebih sulit daripada advance template Yii2).

Secara garis besar (dan mungkin akan bertambah sesuai keperluan yang mungkin terjadi) outline dari seri tulisan ini akan terdiri dari hal berikut.

  1. Prainstalasi
  2. Instalasi YiiFramework 2.0
  3. Login
  4. Login dengan Database pada Yii2
  5. Bekerja dengan Gii
  6. Module pada Yii2
  7. Layout dasar dan Manipulasinya pada Yii2
  8. Costum Asset dan Asset Bundle pada Yii2
  9. Alias pada Yii2
  10. Bekerja dengan Form
  11. Timestamp, Blameable, dan Sluggable Behavior pada Yii2
  12. Menggunakan Rich Text Input CkEditor dan Alternatifnya pada Yii2
  13. Gridview dan Listview
  14. SEO Friendly Url dengan slug
  15. Scenario pada Model Yii2
  16. Retrieve data pada Yii2
  17. Relasi Database pada Yii2
  18. Menggunakan Bootstrap4
  19. Widget Kartik dan Kartik Gridview
  20. Select2 dengan Kartik Ekstension
  21. Dependent Dropdown pada Yii2
  22. Bekerja dengan Modals
  23. Membuat Costum Template untuk Gii
  24. Mengupload File
  25. Mengupload File dengan Kartik Widget
  26. Gridview atau Datatables?
  27. Session dan Cookie pada Yii2
  28. Menggunakan AdminLTE pada Yii2
  29. Membuat Themes pada Yii2
  30. Menggunakan GoogleMaps API pada Yii2
  31. Menggunakan Socket.io pada Yii2
  32. Handling Error
  33. Bekerja dengan AuthClient
  34. Menggunakan Amazon S3 pada Yii2
  35. Mengirim Email dengan Swiftmailer pada Yii2
  36. Middleware pada Yii2
  37. Mengenal RBAC pada Yii2
  38. Implementasi RBAC pada Yii2
  39. Notifikasi Real Time dengan Socket.io pada Yii2

Anda dapat mengunduh dan memantau progress dari series ini lewat repositori Github belajararief-yii2series. Silahkan bintangi (star) untuk dapat lebih mudah memantau perkembangan repositori.

Requirement

Untuk memudahkan anda dalam memahami petunjuk ini, maka beberapa hal yang perlu diperhatikan diantaranya:

  1. Sistem Operasi yang saya gunakan adalah Windows 10 64bit dengan terminal menggunakan powershell terminal (beberapa command seperti cd dapat berbeda dengan command prompt biasa), namun saya akan berusaha sebisa mungkin mencontohkan perintah pada sistem operasi lain jika memunkinkan.
  2. Stack yang digunakan adalah Wamp Server (Apache 2.2, MySQL, PHP 7).
  3. Yii yang digunakan adalah Yii 2.0 dengan catatan jquery yang digunakan bukan jquery3. Beberapa perintah jquery akan berbeda pada jquery3, dan beberapa extensions yang saya gunakan sepertinya belum mendukung jquery3

Mengenal Scenario

Scenario merupakan salah satu metode dalam model. Dalam sebuah aplikasi, tidak jarang sebuah model memiliki beberapa skenario penginputan. Contohnya ketika model User yang digunakan untuk pendaftaran, penambahan, dan login. Pada saat penambahan dan pendaftaran pengguna harus mengisi seluruh field seperti email, username, password. Sedangkan ketika login user cukup mengisi username dan password saja. Perbedaan ini membuat perlu ada 2 rules yang berbeda dalam model, yaitu rules yang membuat email menjadi required dan rule yang membuat email tidak harus required.

Model akan menggunakan properti scenario. Secara default model akan menggunakan scenario bernama default. Sedangkan scenario lain kita susun secara langsung pada model dan di set pada controller.

Pada contoh ini kita akan membuat scenario pada modul blog manajemen. Modul blog manajemen akan membuat user tidak dapat mengubah title dan rules title dihilangkan dari required apabila user yang melakukan update blog bukan user yang sebelumnya membuat blog tersebut.

Penerapan Scenario pada modul Blog

Pada contoh yang akan kita rancang sebelumnya kita akan menambahkan scenario baru sehingga ketika pengguna yang mengubah artikel orang lain tidak dapat mengubah judul dari artikel. Pertama kita akan mengubah model pada file app\models\Blog.php sehingga bagian rules dan menambahkan scenario editByOther menjadi seperti di bawah ini.

    public function rules()
{
return [
[['slug', 'title', 'body'], 'required', 'on' => 'default'],
[['body'], 'required', 'on' => 'editByOther'],
[['body'], 'string'],
[[ 'created_by', 'updated_by'], 'integer'],
['created_at', 'date', 'timestampAttribute' => 'created_at'],
['updated_at', 'date', 'timestampAttribute' => 'updated_at'],
[['slug'], 'string', 'max' => 2048],
[['title'], 'string', 'max' => 512],
];
}

Selanjutnya kita akan mengubah controller agar menerapkan scenario editByOther pada actionUpdate. Ubah file app\modules\administrator\contollers\BlogController.php sehingga pada actionUpdate ditambahkan scenario editByOther menjadi seperti di bawah ini.

    public function actionUpdate($id)
{
$model = $this->findModel($id);

$users = User::find()->select(['id', 'username'])->all();

// if user who update different from user who create, scenario set to editByOther
if($model->created_by != Yii::$app->user->identity->id) $model->scenario = 'editByOther';

if ($model->load(Yii::$app->request->post())) {
// prevent user from change title if that article is not created by them
if($model->created_by != Yii::$app->user->identity->id) $model->title = $model->oldAttributes['title'];
if($model->save()) return $this->redirect(['view', 'id' => $model->id]);
}

return $this->render('update', [
'model' => $model,
'users' => $users,
]);
}

Terakhir kita akan membuat _form menjadi disabled apabila scenario editByOther berlaku. Ubah file app\modules\administrator\views\blog\_form.php sehingga menjadi seperti di bawah ini.

<?php

use yii\helpers\Html;
use yii\widgets\ActiveForm;
use dosamigos\ckeditor\CKEditor;

/* @var $this yii\web\View */
/* @var $model app\models\Blog */
/* @var $form yii\widgets\ActiveForm */
?>

<div class="blog-form">

<?php $form = ActiveForm::begin(); ?>

<?= $form->field($model, 'title')->textInput(['maxlength' => true, 'disabled' => $model->scenario == 'editByOther' ? true : false]) ?>

<?= $form->field($model, 'body')->widget(CKEditor::class, [
'options' => ['rows' => 6],
'preset' => 'basic'
]) ?>

<div class="form-group">
<?= Html::submitButton('Save', ['class' => 'btn btn-success']) ?>
</div>

<?php ActiveForm::end(); ?>

</div>

 


Terimakasih sudah membaca. Semoga bermanfaat dan happy coding!