Make your own blog
Post editing
In this chapter, we will build on our new editing functionality, but first, let's simplify the title HTML block by moving the menu into a separate file:
data:image/s3,"s3://crabby-images/35c98/35c98f60e483355762c50ddca10c327b00fc4b89" alt="Expand/contract code area"
data:image/s3,"s3://crabby-images/d99d1/d99d1f3c0940e98be4dc68f397f2cc8522d55a63" alt="Select previous tab"
- templates/title.php templates/title.php
- templates/top-menu.php templates/top-menu.php
data:image/s3,"s3://crabby-images/e0a28/e0a28b91795481f8a26c47e33b58446e8a3d188c" alt="Select next tab"
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<div class="top-menu">
<div class="menu-options">
<?php if (isLoggedIn()): ?>
<a href="edit-post.php">New post</a>
|
Hello <?php echo htmlEscape(getAuthUser()) ?>.
<a href="logout.php">Log out</a>
<?php else: ?>
<a href="login.php">Log in</a>
<?php endif ?>
</div>
</div>
<a href="index.php">
<h1>Blog title</h1>
1
2
3
4
<?php require 'top-menu.php' ?>
<a href="index.php">
<h1>Blog title</h1>
1
2
3
4
5
6
7
8
9
10
11
12
<div class="top-menu">
<div class="menu-options">
<?php if (isLoggedIn()): ?>
<a href="edit-post.php">New post</a>
|
Hello <?php echo htmlEscape(getAuthUser()) ?>.
<a href="logout.php">Log out</a>
<?php else: ?>
<a href="login.php">Log in</a>
<?php endif ?>
</div>
</div>
That change allows us to wire in the menu fragment separately, without the title, so we can use a custom title in the edit page. You'll see that we set the title to "New post" or "Edit post" depending on whether we can find a primary key in the query string.
data:image/s3,"s3://crabby-images/35c98/35c98f60e483355762c50ddca10c327b00fc4b89" alt="Expand/contract code area"
data:image/s3,"s3://crabby-images/d99d1/d99d1f3c0940e98be4dc68f397f2cc8522d55a63" alt="Select previous tab"
- edit-post.php edit-post.php
data:image/s3,"s3://crabby-images/e0a28/e0a28b91795481f8a26c47e33b58446e8a3d188c" alt="Select next tab"
79
80
81
82
83
84
85
<?php require 'templates/head.php' ?>
</head>
<body>
<?php require 'templates/title.php' ?>
<?php if ($errors): ?>
<div class="error box">
79
80
81
82
83
84
85
86
87
88
89
90
91
<?php require 'templates/head.php' ?>
</head>
<body>
<?php require 'templates/top-menu.php' ?>
<?php if (isset($_GET['post_id'])): ?>
<h1>Edit post</h1>
<?php else: ?>
<h1>New post</h1>
<?php endif ?>
<?php if ($errors): ?>
<div class="error box">
Let's also add in a cancel link in the edit page, to make it easier to abandon an edit:
data:image/s3,"s3://crabby-images/35c98/35c98f60e483355762c50ddca10c327b00fc4b89" alt="Expand/contract code area"
data:image/s3,"s3://crabby-images/d99d1/d99d1f3c0940e98be4dc68f397f2cc8522d55a63" alt="Select previous tab"
- edit-post.php edit-post.php
data:image/s3,"s3://crabby-images/e0a28/e0a28b91795481f8a26c47e33b58446e8a3d188c" alt="Select next tab"
121
122
123
124
125
126
type="submit"
value="Save post"
/>
</div>
</form>
</body>
121
122
123
124
125
126
127
type="submit"
value="Save post"
/>
<a href="index.php">Cancel</a>
</div>
</form>
</body>
On the home page, and for logged-in users only, I next added an edit link against each post, like so:
data:image/s3,"s3://crabby-images/35c98/35c98f60e483355762c50ddca10c327b00fc4b89" alt="Expand/contract code area"
data:image/s3,"s3://crabby-images/d99d1/d99d1f3c0940e98be4dc68f397f2cc8522d55a63" alt="Select previous tab"
- index.php index.php
data:image/s3,"s3://crabby-images/e0a28/e0a28b91795481f8a26c47e33b58446e8a3d188c" alt="Select next tab"
50
51
52
53
54
55
56
57
58
59
<p>
<?php echo htmlEscape($row['body']) ?>
</p>
<div class="read-more">
<a
href="view-post.php?post_id=<?php echo $row['id'] ?>"
>Read more...</a>
</div>
</div>
<?php endwhile ?>
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
<p>
<?php echo htmlEscape($row['body']) ?>
</p>
<div class="post-controls">
<a
href="view-post.php?post_id=<?php echo $row['id'] ?>"
>Read more...</a>
<?php if (isLoggedIn()): ?>
|
<a
href="edit-post.php?post_id=<?php echo $row['id'] ?>"
>Edit</a>
<?php endif ?>
</div>
</div>
<?php endwhile ?>
You may have noticed that the class name (read-more
) of the wrapping div was no
longer accurate, which is why I changed this to something more generic. As it happens, this
section doesn't have any CSS rules specifically attached to it, but it's good to have something
for future styles to hook onto).
Lastly, let's make a another nice easy change - there's no point in rendering the login page if we are already logged in. So, after the session is started, if we find we are logged in already, redirect back to the home page.
data:image/s3,"s3://crabby-images/35c98/35c98f60e483355762c50ddca10c327b00fc4b89" alt="Expand/contract code area"
data:image/s3,"s3://crabby-images/d99d1/d99d1f3c0940e98be4dc68f397f2cc8522d55a63" alt="Select previous tab"
- login.php login.php
data:image/s3,"s3://crabby-images/e0a28/e0a28b91795481f8a26c47e33b58446e8a3d188c" alt="Select next tab"
10
11
12
13
14
15
}
session_start();
// Handle the form posting
$username = '';
10
11
12
13
14
15
16
17
18
19
20
21
}
session_start();
// If we're already logged in, go back home
if (isLoggedIn())
{
redirectAndExit('index.php');
}
// Handle the form posting
$username = '';