blob: b7ded3b3a4268e189f07da808e5b86f1cb47a479 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
|
<com:TContent ID="Main">
<h1>Membuat Halaman <tt>EditPost</tt></h1>
<p>
Halaman <tt>EditPost</tt> disediakan bagi para pembuat dan administrator untuk mengedit tulisan blog yang sudah ada. Seperti halaman <a href="?page=Day4.CreateNewPost">NewPost</a> , ia menampilkan sebuah formulir untuk mengumpulkan perubahan terhadap judul dan konten tulisan.
</p>
<p>
Kita membuat dua file <tt>protected/pages/posts/EditPost.page</tt> dan <tt>protected/pages/posts/EditPost.php</tt> masing-masing untuk menyimpan template halaman dan kelas halaman.
</p>
<h2>Membuat Template Halaman</h2>
<p>
Template halaman <tt>EditPost</tt> sangat mirip dengan template <tt>NewPost</tt>. Hanya judul halaman dan tombol yang berbeda.
</p>
<com:TTextHighlighter CssClass="source" Language="prado">
<%@ Title="My Blog - Edit Post" %>
<com:TContent ID="Main">
<h1>Edit Post</h1>
<span>Title:</span>
<com:TRequiredFieldValidator
ControlToValidate="TitleEdit"
ErrorMessage="Please provide a title."
Display="Dynamic" />
<br/>
<com:TTextBox ID="TitleEdit" Columns="50" />
<br/>
<span>Content:</span>
<com:TRequiredFieldValidator
ControlToValidate="ContentEdit"
ErrorMessage="Please provide content."
Display="Dynamic" />
<br/>
<com:THtmlArea ID="ContentEdit" />
<br/>
<com:TButton Text="Save" OnClick="saveButtonClicked" />
</com:TContent>
</com:TTextHighlighter>
<h2>Membuat Kelas Halaman</h2>
<p>
Kelas halaman <tt>EditPage</tt> lebih kompleks dibanding <tt>NewPage</tt> karena ia perlu mengambil data tulisan yang ditetapkan terlebih dulu. Ia juga perlu melakukan pemeriksaan otorisasi tambahan. Ada kalanya ia perlu memastikan bahwa tulisan hanya bisa diedit oleh pembuat atau administrator. Pemeriksaan otorisasi sudah disediakan oleh PRADO.
</p>
<com:TTextHighlighter CssClass="source" Language="php">
class EditPost extends TPage
{
/**
* Menginisialisasi input dengan data tulisan yang sudah ada.
* Metode ini dipanggil oleh kerangka kerja saat halaman diinisialisasi.
* @param parameter event campuran
*/
public function onInit($param)
{
parent::onInit($param);
// Menambil data pengguna yang sudah ada. Ini sama dengan:
// $postRecord=$this->getPost();
$postRecord=$this->Post;
// Pemeriksaan otorisasi: hanya pembuat atau administrator dapat mengedit tulisan
if($postRecord->author_id!==$this->User->Name && !$this->User->IsAdmin)
throw new THttpException(500,'You are not allowed to edit this post.');
if(!$this->IsPostBack) // jika halaman pertama kali diminta
{
// Mempopulasikan kontrol input dengan data tulisan yang sudah ada
$this->TitleEdit->Text=$postRecord->title;
$this->ContentEdit->Text=$postRecord->content;
}
}
/**
* Menyimpan tulisan jika semua input sudah benar.
* Metode ini merespon event OnClick pada tombol "Save".
* @param pengirim event campuran
* @param parameter event campuran
*/
public function saveButtonClicked($sender,$param)
{
if($this->IsValid) // jika semua validasi sukses
{
// Mengambil data pengguna yang sudah ada. Ini sama dengan:
// $postRecord=$this->getPost();
$postRecord=$this->Post;
// Mengambil data input
$postRecord->title=$this->TitleEdit->SafeText;
$postRecord->content=$this->ContentEdit->SafeText;
// menyimpan ke database via mekanisme Rekaman Aktif
$postRecord->save();
// mengalihkan browser ke halaman ReadPost
$url=$this->Service->constructUrl('posts.ReadPost',array('id'=>$postRecord->post_id));
$this->Response->redirect($url);
}
}
/**
* Mengembalikan data tulisan yang akan diedit.
* @return PostRecord data tulisan yang akan diedit.
* @throws THttpException jika data tulisan tidak ada.
*/
protected function getPost()
{
// ID tulisan yang diedit dikirimkan via parameter GET 'id'
$postID=(int)$this->Request['id'];
// gunakan Rekaman Aktif untuk mencari ID tulisan tertentu
$postRecord=PostRecord::finder()->findByPk($postID);
if($postRecord===null)
throw new THttpException(500,'Post is not found.');
return $postRecord;
}
}
</com:TTextHighlighter>
<h2>Pengujian</h2>
<p>
Untuk menguji halaman <tt>EditPost</tt>, masuk lebih dulu dan kemudian kunjungi URL berikut: <tt>http://hostname/blog/index.php?page=EditPost&id=1</tt>. URL ini juga bisa dijangkau dengan mengklik link <tt>Edit</tt> pada halaman rician tulisan.
</p>
<img src="<%~ output4.gif %>" class="output" />
</com:TContent>
|