diff --git a/contrib/featured/main.php b/contrib/featured/main.php index bd291bd6..eebc16b5 100644 --- a/contrib/featured/main.php +++ b/contrib/featured/main.php @@ -9,6 +9,13 @@ * to the other image control buttons (delete, rotate, etc). * Clicking it will set the image as the site's current feature, * which will be shown in the side bar of the post list. + *
Viewing a featured image
+ *
Visit /featured_image/view
+ *
Downloading a featured image
+ *
Link to /featured_image/download
. This will give
+ * the raw data for an image (no HTML). This is useful so that you
+ * can set your desktop wallpaper to be the download URL, refreshed
+ * every couple of hours.
*/
class Featured extends SimpleExtension {
@@ -19,13 +26,29 @@ class Featured extends SimpleExtension {
public function onPageRequest($event) {
global $config, $page, $user;
- if($event->page_matches("set_feature")) {
- if($user->is_admin() && isset($_POST['image_id'])) {
- $id = int_escape($_POST['image_id']);
- if($id > 0) {
- $config->set_int("featured_id", $id);
- $page->set_mode("redirect");
- $page->set_redirect(make_link("post/view/$id"));
+ if($event->page_matches("featured_image")) {
+ if($event->get_arg(0) == "set") {
+ if($user->is_admin() && isset($_POST['image_id'])) {
+ $id = int_escape($_POST['image_id']);
+ if($id > 0) {
+ $config->set_int("featured_id", $id);
+ $page->set_mode("redirect");
+ $page->set_redirect(make_link("post/view/$id"));
+ }
+ }
+ }
+ if($event->get_arg(0) == "download") {
+ $image = Image::by_id($config->get_int("featured_id"));
+ if(!is_null($image)) {
+ $page->set_mode("data");
+ $page->set_type("image/jpeg");
+ $page->set_data(file_get_contents($image->get_image_filename()));
+ }
+ }
+ if($event->get_arg(0) == "view") {
+ $image = Image::by_id($config->get_int("featured_id"));
+ if(!is_null($image)) {
+ send_event(new DisplayingImageEvent($image, $page));
}
}
}
diff --git a/contrib/featured/theme.php b/contrib/featured/theme.php
index b6f9c0f2..ff2fb9ae 100644
--- a/contrib/featured/theme.php
+++ b/contrib/featured/theme.php
@@ -10,7 +10,7 @@ class FeaturedTheme extends Themelet {
public function get_buttons_html($image_id) {
return "
-