/3.0/modules/pages_xtra/controllers/admin_pages_xtra.php
PHP | 331 lines | 230 code | 51 blank | 50 comment | 16 complexity | d5168d7a2cbd596d3eb67eb98be48352 MD5 | raw file
Possible License(s): GPL-3.0, GPL-2.0, LGPL-2.1
- <?php defined("SYSPATH") or die("No direct script access.");
- /**
- * Gallery - a web based photo album viewer and editor
- * Copyright (C) 2000-2014 Bharat Mediratta
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or (at
- * your option) any later version.
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
- */
- class Admin_Pages_xtra_Controller extends Admin_Controller {
- public function index() {
- // Display the admin page.
- $view = new Admin_View("admin.html");
- $view->page_title = t("Manage pages");
- $view->content = new View("admin_pages_xtra.html");
- $query = ORM::factory("px_static_page");
- $view->content->pages = $query->order_by("name", "ASC")->find_all();
- $view->content->form = $this->get_prefs_form();
- print $view;
- }
- public function createpage() {
- // Display a form for creating a new page.
- $view = new Admin_View("admin.html");
- $view->page_title = t("Create page");
- $view->content = new View("admin_pages_xtra_new.html");
- $view->content->form = $this->get_new_page_form();
- print $view;
- }
- public function editpage($id) {
- // Display a form for editing an existing page.
- $existing_page = ORM::factory("px_static_page", $id);
- $view = new Admin_View("admin.html");
- $view->page_title = t("Edit page");
- $view->content = new View("admin_pages_xtra_new.html");
- $view->content->form = $this->get_edit_page_form($existing_page);
- print $view;
- }
- public function savepage() {
- // Save a page to the database.
- access::verify_csrf();
- // Store form values into variables.
- $page_id = Input::instance()->post("page_id");
- $page_name = urlencode(trim(Input::instance()->post("page_name")));
- $page_title = Input::instance()->post("page_title");
-
- // Define relative_url_cache as a derivative of page name
- $page_relative_url_cache = "pages_xtra/show/$page_name";
-
- $page_description = Input::instance()->post("page_description");
- $page_tags = Input::instance()->post("page_tags");
-
- /* $page_code = stripslashes($_REQUEST["page_code"]); // access var directly to get around xss filtering. */
- // Change above line (from Pages module V3) to next line (from Pages module V2) - if data does not save to database!
- $page_code = Input::instance()->post("page_code");
-
- $display_menu = Input::instance()->post("display_menu");
- $page_type = Input::instance()->post("page_type");
- // If $page_id is set, update an existing page.
- if (isset($page_id)) {
- $update_page = ORM::factory("px_static_page", $page_id);
- $update_page->title = $page_title;
-
- $update_page->relative_url_cache = $page_relative_url_cache;
- $update_page->description = $page_description;
- $update_page->tags = $page_tags;
- $update_page->html_code = $page_code;
- $update_page->display_menu = $display_menu;
-
- $update_page->type = $page_type;
- $update_page->save();
- message::success(t("Page %page_name updated", array("page_name" => $update_page->name)));
- log::success("pages_xtra", t("Page %page_name updated", array("page_name" => $update_page->name)));
- url::redirect("admin/pages_xtra");
- } else {
- // If $page_id is not set, we are dealing with a new page.
- // Check and make sure a page with the same names doesn't already exist.
- $existing_page = ORM::factory("px_static_page")
- ->where("name", "=", $page_name)
- ->find_all();
- // If the page doesn't exist, save it to the database.
- if (count($existing_page) == 0) {
- $new_page = ORM::factory("px_static_page");
- $new_page->name = $page_name;
- $new_page->title = $page_title;
- $new_page->relative_url_cache = $relative_url_cache;
- $new_page->description = $page_description;
- $new_page->tags = $page_tags;
- $new_page->html_code = $page_code;
- $new_page->display_menu = $display_menu;
- $new_page->type = $page_type;
- $new_page->save();
- message::success(t("Page %page_name created", array("page_name" => $page_name)));
- log::success("pages_xtra", t("Page %page_name created", array("page_name" => $page_name)));
- url::redirect("admin/pages_xtra");
- } else {
- // If the page does exist, ask the user if they want to overwrite the old page with the new one.
- message::error(t("Page %page_name already exists, press Save again to overwrite.", array("page_name" => $page_name)));
- $view = new Admin_View("admin.html");
- $view->page_title = t("Edit page");
- $view->content = new View("admin_pages_xtra_new.html");
-
- $view->content->form = $this->get_overwrite_page_form($existing_page[0]->id, $page_name, $page_title, $page_description, $page_tags, $page_code, $display_menu, $page_type);
- print $view;
- }
- }
- }
- public function form_delete($id) {
- // Display a form asking the user if they want to delete a page.
- $one_page = ORM::factory("px_static_page", $id);
- if ($one_page->loaded()) {
- print $this->get_delete_form($one_page);
- }
- }
- public function delete($id) {
- // Delete the specified page.
- access::verify_csrf();
- // Make sure $id belongs to an actual page.
- $one_page = ORM::factory("px_static_page", $id);
- if (!$one_page->loaded()) {
- throw new Kohana_404_Exception();
- }
- // If the form validates, delete the specified page.
- $form = $this->get_delete_form($one_page);
- if ($form->validate()) {
- $name = $one_page->name;
- $one_page->delete();
- message::success(t("Deleted page %page_name", array("page_name" => $name)));
- log::success("pages_xtra", t("Deleted page %page_name", array("page_name" => $name)));
- json::reply(array("result" => "success", "location" => url::site("admin/pages_xtra")));
- } else {
- print $form;
- }
- }
- public function form_rename($id) {
- // Display a form to allow the user to rename a page.
- $one_page = ORM::factory("px_static_page", $id);
- if ($one_page->loaded()) {
- print InPlaceEdit::factory(urldecode($one_page->name))
- ->action("admin/pages_xtra/rename/$id")
- ->render();
- }
- }
- public function rename($id) {
- // Rename an existing page.
- access::verify_csrf();
- // Make sure the page specified by $id exists.
- $one_page = ORM::factory("px_static_page", $id);
- if (!$one_page->loaded()) {
- throw new Kohana_404_Exception();
- }
- $in_place_edit = InPlaceEdit::factory($one_page->name)
- ->action("admin/pages_xtra/rename/$one_page->id")
- ->rules(array("required", "length[1,64]"));
- // If the form validates, and if the new name doesn't already exist, rename the page.
- if ($in_place_edit->validate()) {
- $old_name = $one_page->name;
- $new_name = urlencode(trim($in_place_edit->value()));
- $new_name_exists = ORM::factory("px_static_page")->where("name", "=", $new_name)->find_all();
- if (count($new_name_exists) == 0) {
- $one_page->name = $new_name;
- $one_page->save();
- $message = t("Renamed page <i>%old_name</i> to <i>%new_name</i>",
- array("old_name" => $old_name, "new_name" => $new_name));
- message::success($message);
- log::success("pages_xtra", $message);
- json::reply(array("result" => "success", "location" => url::site("admin/pages_xtra")));
- } else {
- json::reply(array("result" => "error", "form" => (string)$in_place_edit->render()));
- }
- } else {
- json::reply(array("result" => "error", "form" => (string)$in_place_edit->render()));
- }
- }
- static function get_delete_form($one_page) {
- // Generate a new form asking the user if they want to delete a page.
- $form = new Forge("admin/pages_xtra/delete/$one_page->id", "", "post", array("id" => "g-delete-pages-form"));
- $group = $form->group("delete_page")
- ->label(t("Really delete page %page_name?", array("page_name" => $one_page->name)));
- $group->submit("")->value(t("Delete Page"));
- return $form;
- }
- private function get_new_page_form() {
- // Generate a form for creating a new page.
- $form = new Forge("admin/pages_xtra/savepage", "", "post",
- array("id" => "g-pages-admin-form"));
- $pages_group = $form->group("new_page")->label(t("Page Settings"));;
- $pages_group->input("page_name")
- ->label(t("Name / URL extension   [No gaps between words. Only hyphen(-) or underscore(_) allowed]"));
- $pages_group->input("page_title")
- ->label(t("Title"));
- $pages_group->input("page_description")
- ->label(t("Description [approx 150 chars max]"))
- ->css_id("g-description-input");
- $pages_group->input("page_tags")
- ->label(t("Tags / Keywords [comma separated]"));
-
- $pages_group->textarea("page_code")
- ->label(t("HTML Code   [Notes: 1. Page 'Body' only.   2. Tags with 'style=' may not save correctly. Use CSS in your theme]"));
- $pages_group->checkbox("display_menu")
- ->label(t("Display link in sidebar menu?"))
- ->checked(false);
- $pages_group->checkbox("page_type")
- ->label(t("Include URL in Sitemap? [Requires Sitemap_xtra Module]"))
- ->checked(false);
- $pages_group->submit("save_page")
- ->value(t("Save"));
- return $form;
- }
- // Add all new px_static_pages variables VISIBLE on the form (plus id), to following private overwrite function,
- // so all info is called correctly from database.
- private function get_overwrite_page_form($id, $name, $title, $description, $tags, $html_code, $display_menu, $type) {
- // Generate a form for overwriting an existing page. ie. Edit the Page
-
- $form = new Forge("admin/pages_xtra/savepage", "", "post",
- array("id" => "g-pages-admin-form"));
- $pages_group = $form->group("new_page")->label(t("Page Settings"));;
- $pages_group->hidden("page_id")
- ->value($id);
- $pages_group->input("page_name")
- ->label(t("Name / URL extension   [No gaps between words. Only hyphen(-) or underscore(_) allowed]"))
- ->readonly()
- ->value($name);
- $pages_group->input("page_title")
- ->label(t("Title"))
- ->value($title);
- $pages_group->input("page_description")
- ->label(t("Description [approx 150 chars max]"))
- ->value($description);
- // ->css_id("g-description-input");
- $pages_group->input("page_tags")
- ->label(t("Tags / Keywords [comma separated]"))
- ->value($tags);
-
- $pages_group->textarea("page_code")
- ->label(t("HTML Code   [Notes: 1. Page 'Body' only.   2. Tags with 'style=' may not save correctly. Use CSS in your theme]"))
- ->value($html_code);
- $pages_group->checkbox("display_menu")
- ->label(t("Display link in sidebar menu?"))
- ->checked($display_menu);
- $pages_group->checkbox("page_type")
- ->label(t("Include URL in Sitemap? [Requires Sitemap_xtra Module]"))
- ->checked($type);
-
- $pages_group->submit("save_page")
- ->value(t("Save"));
- return $form;
- }
- private function get_edit_page_form($existing_page) {
- // Generate a form for editing an existing page. Reuse the overwrite form for as it's basically the same thing.
-
- return ($this->get_overwrite_page_form($existing_page->id, $existing_page->name, $existing_page->title, $existing_page->description, $existing_page->tags, $existing_page->html_code, $existing_page->display_menu, $existing_page->type));
- }
- private function get_prefs_form() {
- // Generate a form for global preferences.
- $form = new Forge("admin/pages_xtra/saveprefs", "", "post",
- array("id" => "g-pages-admin-form"));
- $pages_group = $form->group("preferences")->label(t("Global Settings"));
-
- $pages_group->input("site_title")
- ->label(t("Website Title"))
- ->value(module::get_var("pages_xtra", "site_title"));
- $pages_group->checkbox("display_sidebar")
- ->label(t("Hide sidebar on Pages?"))
- ->checked(module::get_var("pages_xtra", "show_sidebar"));
- $pages_group->checkbox("disable_rich_editor")
- ->label(t("Disable rich text editor?"))
- ->checked(module::get_var("pages_xtra", "disable_rte"));
- $pages_group->submit("save_prefs")
- ->value(t("Save"));
- return $form;
- }
- public function saveprefs() {
- // Save a preferences to the database.
- access::verify_csrf();
- // Save form variables.
- module::set_var("pages_xtra", "show_sidebar", Input::instance()->post("display_sidebar"));
- module::set_var("pages_xtra", "disable_rte", Input::instance()->post("disable_rich_editor"));
-
- module::set_var("pages_xtra", "site_title", Input::instance()->post("site_title"));
-
- // Display message and load main pages admin screen.
- message::success(t("Your settings have been saved."));
- url::redirect("admin/pages_xtra");
- }
- }