mirror of
https://github.com/monstra-cms/monstra.git
synced 2025-07-31 18:30:20 +02:00
Pages Plugin: Update Index Action.
This commit is contained in:
@@ -11,484 +11,495 @@
|
||||
*/
|
||||
public static function main() {
|
||||
|
||||
$current_theme = Option::get('theme_site_name');
|
||||
$site_url = Option::get('siteurl');
|
||||
$current_theme = Option::get('theme_site_name');
|
||||
$site_url = Option::get('siteurl');
|
||||
|
||||
$templates_path = THEMES_SITE;
|
||||
$templates_path = THEMES_SITE;
|
||||
|
||||
$errors = array();
|
||||
$errors = array();
|
||||
|
||||
$pages = new Table('pages');
|
||||
$users = new Table('users');
|
||||
$pages = new Table('pages');
|
||||
$users = new Table('users');
|
||||
|
||||
$user = $users->select('[id='.Session::get('user_id').']', null);
|
||||
$user = $users->select('[id='.Session::get('user_id').']', null);
|
||||
|
||||
$user['firstname'] = Html::toText($user['firstname']);
|
||||
$user['lastname'] = Html::toText($user['lastname']);
|
||||
$user['firstname'] = Html::toText($user['firstname']);
|
||||
$user['lastname'] = Html::toText($user['lastname']);
|
||||
|
||||
// Page author
|
||||
if (isset($user['firstname']) && trim($user['firstname']) !== '') {
|
||||
if (trim($user['lastname']) !== '') $lastname = ' '.$user['lastname']; else $lastname = '';
|
||||
$author = $user['firstname'] . $lastname;
|
||||
} else {
|
||||
$author = Session::get('user_login');
|
||||
}
|
||||
|
||||
// Page author
|
||||
if (isset($user['firstname']) && trim($user['firstname']) !== '') {
|
||||
if (trim($user['lastname']) !== '') $lastname = ' '.$user['lastname']; else $lastname = '';
|
||||
$author = $user['firstname'] . $lastname;
|
||||
} else {
|
||||
$author = Session::get('user_login');
|
||||
}
|
||||
|
||||
|
||||
// Status array
|
||||
$status_array = array('published' => __('Published', 'pages'),
|
||||
'draft' => __('Draft', 'pages'));
|
||||
// Status array
|
||||
$status_array = array('published' => __('Published', 'pages'),
|
||||
'draft' => __('Draft', 'pages'));
|
||||
|
||||
|
||||
// Check for get actions
|
||||
// ---------------------------------------------
|
||||
if (Request::get('action')) {
|
||||
|
||||
// Switch actions
|
||||
// -----------------------------------------
|
||||
switch (Request::get('action')) {
|
||||
|
||||
// Check for get actions
|
||||
// ---------------------------------------------
|
||||
if (Request::get('action')) {
|
||||
|
||||
// Switch actions
|
||||
// -----------------------------------------
|
||||
switch (Request::get('action')) {
|
||||
|
||||
// Clone page
|
||||
// -------------------------------------
|
||||
case "clone_page":
|
||||
|
||||
// Generate rand page name
|
||||
$rand_page_name = Request::get('name').'_clone_'.date("Ymd_His");
|
||||
|
||||
// Get original page
|
||||
$orig_page = $pages->select('[slug="'.Request::get('name').'"]', null);
|
||||
|
||||
// Clone page
|
||||
// -------------------------------------
|
||||
case "clone_page":
|
||||
|
||||
// Generate rand page name
|
||||
$rand_page_name = Request::get('name').'_clone_'.date("Ymd_His");
|
||||
if($pages->insert(array('slug' => $rand_page_name,
|
||||
'template' => $orig_page['template'],
|
||||
'parent' => $orig_page['parent'],
|
||||
'robots_index' => $orig_page['robots_index'],
|
||||
'robots_follow'=> $orig_page['robots_follow'],
|
||||
'status' => $orig_page['status'],
|
||||
'title' => $rand_page_name,
|
||||
'description' => $orig_page['description'],
|
||||
'keywords' => $orig_page['keywords'],
|
||||
'date' => $orig_page['date'],
|
||||
'author' => $orig_page['author']))) {
|
||||
|
||||
// Get cloned page ID
|
||||
$last_id = $pages->lastId();
|
||||
|
||||
// Get original page
|
||||
$orig_page = $pages->select('[slug="'.Request::get('name').'"]', null);
|
||||
// Save cloned page content
|
||||
File::setContent(STORAGE . DS . 'pages' . DS . $last_id . '.page.txt',
|
||||
File::getContent(STORAGE . DS . 'pages' . DS . $orig_page['id'] . '.page.txt'));
|
||||
|
||||
// Clone page
|
||||
if($pages->insert(array('slug' => $rand_page_name,
|
||||
'template' => $orig_page['template'],
|
||||
'parent' => $orig_page['parent'],
|
||||
'robots_index' => $orig_page['robots_index'],
|
||||
'robots_follow'=> $orig_page['robots_follow'],
|
||||
'status' => $orig_page['status'],
|
||||
'title' => $rand_page_name,
|
||||
'description' => $orig_page['description'],
|
||||
'keywords' => $orig_page['keywords'],
|
||||
'date' => $orig_page['date'],
|
||||
'author' => $orig_page['author']))) {
|
||||
|
||||
// Get cloned page ID
|
||||
$last_id = $pages->lastId();
|
||||
// Send notification
|
||||
Notification::set('success', __('The page <i>:page</i> cloned.', 'pages', array(':page' => Security::safeName(Request::get('name'), '-', true))));
|
||||
}
|
||||
|
||||
// Save cloned page content
|
||||
File::setContent(STORAGE . DS . 'pages' . DS . $last_id . '.page.txt',
|
||||
File::getContent(STORAGE . DS . 'pages' . DS . $orig_page['id'] . '.page.txt'));
|
||||
// Run add extra actions
|
||||
Action::run('admin_pages_action_clone');
|
||||
|
||||
// Send notification
|
||||
Notification::set('success', __('The page <i>:page</i> cloned.', 'pages', array(':page' => Security::safeName(Request::get('name'), '-', true))));
|
||||
}
|
||||
// Redirect
|
||||
Request::redirect('index.php?id=pages');
|
||||
break;
|
||||
|
||||
// Run add extra actions
|
||||
Action::run('admin_pages_action_clone');
|
||||
// Add page
|
||||
// -------------------------------------
|
||||
case "add_page":
|
||||
|
||||
// Redirect
|
||||
Request::redirect('index.php?id=pages');
|
||||
break;
|
||||
// Add page
|
||||
if (Request::post('add_page') || Request::post('add_page_and_exit')) {
|
||||
|
||||
// Add page
|
||||
// -------------------------------------
|
||||
case "add_page":
|
||||
if (Security::check(Request::post('csrf'))) {
|
||||
|
||||
// Get parent page
|
||||
if (Request::post('pages') == '0') {
|
||||
$parent_page = '';
|
||||
} else {
|
||||
$parent_page = Request::post('pages');
|
||||
}
|
||||
|
||||
// Add page
|
||||
if (Request::post('add_page') || Request::post('add_page_and_exit')) {
|
||||
|
||||
if (Security::check(Request::post('csrf'))) {
|
||||
|
||||
// Get parent page
|
||||
if (Request::post('pages') == '0') {
|
||||
$parent_page = '';
|
||||
} else {
|
||||
$parent_page = Request::post('pages');
|
||||
// Validate
|
||||
//--------------
|
||||
if (trim(Request::post('page_name')) == '') $errors['pages_empty_name'] = __('Required field', 'pages');
|
||||
if (trim(Request::post('page_title')) == '') $errors['pages_empty_title'] = __('Required field', 'pages');
|
||||
if (count($pages->select('[slug="'.Security::safeName(Request::post('page_name'), '-', true).'"]')) != 0) $errors['pages_exists'] = __('This page already exists', 'pages');
|
||||
|
||||
|
||||
// Prepare date
|
||||
if (Valid::date(Request::post('page_date'))) {
|
||||
$date = strtotime(Request::post('page_date'));
|
||||
} else {
|
||||
$date = time();
|
||||
}
|
||||
|
||||
if (Request::post('robots_index')) $robots_index = 'noindex'; else $robots_index = 'index';
|
||||
if (Request::post('robots_follow')) $robots_follow = 'nofollow'; else $robots_follow = 'follow';
|
||||
|
||||
// If no errors then try to save
|
||||
if (count($errors) == 0) {
|
||||
|
||||
// Insert new page
|
||||
if($pages->insert(array('slug' => Security::safeName(Request::post('page_name'), '-', true),
|
||||
'template' => Request::post('templates'),
|
||||
'parent' => $parent_page,
|
||||
'status' => Request::post('status'),
|
||||
'robots_index' => $robots_index,
|
||||
'robots_follow'=> $robots_follow,
|
||||
'title' => Request::post('page_title'),
|
||||
'description' => Request::post('page_description'),
|
||||
'keywords' => Request::post('page_keywords'),
|
||||
'date' => $date,
|
||||
'author' => $author))) {
|
||||
|
||||
// Get inserted page ID
|
||||
$last_id = $pages->lastId();
|
||||
|
||||
// Save content
|
||||
File::setContent(STORAGE . DS . 'pages' . DS . $last_id . '.page.txt', XML::safe(Request::post('editor')));
|
||||
|
||||
// Send notification
|
||||
Notification::set('success', __('Your changes to the page <i>:page</i> have been saved.', 'pages', array(':page' => Security::safeName(Request::post('page_title'), '-', true))));
|
||||
}
|
||||
|
||||
|
||||
// Validate
|
||||
//--------------
|
||||
if (trim(Request::post('page_name')) == '') $errors['pages_empty_name'] = __('Required field', 'pages');
|
||||
if (trim(Request::post('page_title')) == '') $errors['pages_empty_title'] = __('Required field', 'pages');
|
||||
if (count($pages->select('[slug="'.Security::safeName(Request::post('page_name'), '-', true).'"]')) != 0) $errors['pages_exists'] = __('This page already exists', 'pages');
|
||||
|
||||
|
||||
// Prepare date
|
||||
if (Valid::date(Request::post('page_date'))) {
|
||||
$date = strtotime(Request::post('page_date'));
|
||||
// Run add extra actions
|
||||
Action::run('admin_pages_action_add');
|
||||
|
||||
// Redirect
|
||||
if (Request::post('add_page_and_exit')) {
|
||||
Request::redirect('index.php?id=pages');
|
||||
} else {
|
||||
$date = time();
|
||||
}
|
||||
Request::redirect('index.php?id=pages&action=edit_page&name='.Security::safeName(Request::post('page_name'), '-', true));
|
||||
}
|
||||
}
|
||||
|
||||
if (Request::post('robots_index')) $robots_index = 'noindex'; else $robots_index = 'index';
|
||||
if (Request::post('robots_follow')) $robots_follow = 'nofollow'; else $robots_follow = 'follow';
|
||||
|
||||
// If no errors then try to save
|
||||
if (count($errors) == 0) {
|
||||
|
||||
// Insert new page
|
||||
if($pages->insert(array('slug' => Security::safeName(Request::post('page_name'), '-', true),
|
||||
'template' => Request::post('templates'),
|
||||
'parent' => $parent_page,
|
||||
'status' => Request::post('status'),
|
||||
'robots_index' => $robots_index,
|
||||
'robots_follow'=> $robots_follow,
|
||||
'title' => Request::post('page_title'),
|
||||
'description' => Request::post('page_description'),
|
||||
'keywords' => Request::post('page_keywords'),
|
||||
'date' => $date,
|
||||
'author' => $author))) {
|
||||
} else { die('csrf detected!'); }
|
||||
|
||||
// Get inserted page ID
|
||||
$last_id = $pages->lastId();
|
||||
}
|
||||
|
||||
// Save content
|
||||
File::setContent(STORAGE . DS . 'pages' . DS . $last_id . '.page.txt', XML::safe(Request::post('editor')));
|
||||
// Get all pages
|
||||
$pages_list = $pages->select('[slug!="error404" and parent=""]');
|
||||
$pages_array[] = '-none-';
|
||||
foreach ($pages_list as $page) {
|
||||
$pages_array[$page['slug']] = $page['title'];
|
||||
}
|
||||
|
||||
// Send notification
|
||||
// Get all templates
|
||||
$templates_list = File::scan($templates_path, '.template.php');
|
||||
foreach ($templates_list as $file) {
|
||||
$templates_array[basename($file, '.template.php')] = basename($file, '.template.php');
|
||||
}
|
||||
|
||||
// Save fields
|
||||
if (Request::post('page_name')) $post_name = Request::post('page_name'); else $post_name = '';
|
||||
if (Request::post('page_title')) $post_title = Request::post('page_title'); else $post_title = '';
|
||||
if (Request::post('page_keywords')) $post_keywords = Request::post('page_keywords'); else $post_keywords = '';
|
||||
if (Request::post('page_description')) $post_description = Request::post('page_description'); else $post_description = '';
|
||||
if (Request::post('editor')) $post_content = Request::post('editor'); else $post_content = '';
|
||||
if (Request::post('templates')) $post_template = Request::post('templates'); else $post_template = 'index';
|
||||
if (Request::post('pages')) $parent_page = Request::post('pages'); else $parent_page = '';
|
||||
if (Request::post('robots_index')) $post_robots_index = true; else $post_robots_index = false;
|
||||
if (Request::post('robots_follow')) $post_robots_follow = true; else $post_robots_follow = false;
|
||||
//--------------
|
||||
|
||||
// Generate date
|
||||
$date = Date::format(time(), 'Y-m-d H:i:s');
|
||||
|
||||
// Set Tabs State - page
|
||||
Notification::setNow('page', 'page');
|
||||
|
||||
// Display view
|
||||
View::factory('box/pages/views/backend/add')
|
||||
->assign('post_name', $post_name)
|
||||
->assign('post_title', $post_title)
|
||||
->assign('post_description', $post_description)
|
||||
->assign('post_keywords', $post_keywords)
|
||||
->assign('post_content', $post_content)
|
||||
->assign('pages_array', $pages_array)
|
||||
->assign('parent_page', $parent_page)
|
||||
->assign('templates_array', $templates_array)
|
||||
->assign('post_template', $post_template)
|
||||
->assign('status_array', $status_array)
|
||||
->assign('date', $date)
|
||||
->assign('post_robots_index', $post_robots_index)
|
||||
->assign('post_robots_follow', $post_robots_follow)
|
||||
->assign('errors', $errors)
|
||||
->display();
|
||||
|
||||
break;
|
||||
|
||||
// Edit page
|
||||
// -------------------------------------
|
||||
case "edit_page":
|
||||
|
||||
if (Request::post('edit_page') || Request::post('edit_page_and_exit')) {
|
||||
|
||||
if (Security::check(Request::post('csrf'))) {
|
||||
|
||||
// Get pages parent
|
||||
if (Request::post('pages') == '0') {
|
||||
$parent_page = '';
|
||||
} else {
|
||||
$parent_page = Request::post('pages');
|
||||
}
|
||||
// Save field
|
||||
$post_parent = Request::post('pages');
|
||||
|
||||
|
||||
// Validate
|
||||
//--------------
|
||||
if (trim(Request::post('page_name')) == '') $errors['pages_empty_name'] = __('This field should not be empty', 'pages');
|
||||
|
||||
$_page = $pages->select('[slug="'.Security::safeName(Request::post('page_name'), '-', true).'"]');
|
||||
|
||||
if ((count($_page) != 0) and (Security::safeName(Request::post('page_old_name'), '-', true) !== Security::safeName(Request::post('page_name'), '-', true))) $errors['pages_exists'] = __('This page already exists', 'pages');
|
||||
|
||||
if (trim(Request::post('page_title')) == '') $errors['pages_empty_title'] = __('This field should not be empty', 'pages');
|
||||
|
||||
// Save fields
|
||||
if (Request::post('page_name')) $post_name = Request::post('page_name'); else $post_name = '';
|
||||
if (Request::post('page_title')) $post_title = Request::post('page_title'); else $post_title = '';
|
||||
if (Request::post('page_keywords')) $post_keywords = Request::post('page_keywords'); else $post_keywords = '';
|
||||
if (Request::post('page_description')) $post_description = Request::post('page_description'); else $post_description = '';
|
||||
if (Request::post('editor')) $post_content = Request::post('editor'); else $post_content = '';
|
||||
if (Request::post('templates')) $post_template = Request::post('templates'); else $post_template = 'index';
|
||||
if (Request::post('robots_index')) $post_robots_index = true; else $post_robots_index = false;
|
||||
if (Request::post('robots_follow')) $post_robots_follow = true; else $post_robots_follow = false;
|
||||
//--------------
|
||||
|
||||
// Generate date
|
||||
$date = mktime(Request::post('hour'),
|
||||
Request::post('minute'),
|
||||
Request::post('second'),
|
||||
Request::post('month'),
|
||||
Request::post('day'),
|
||||
Request::post('year'));
|
||||
|
||||
if (Request::post('robots_index')) $robots_index = 'noindex'; else $robots_index = 'index';
|
||||
if (Request::post('robots_follow')) $robots_follow = 'nofollow'; else $robots_follow = 'follow';
|
||||
|
||||
if (count($errors) == 0) {
|
||||
|
||||
// Update parents in all childrens
|
||||
if ((Security::safeName(Request::post('page_name'), '-', true)) !== (Security::safeName(Request::post('page_old_name'), '-', true)) and (Request::post('old_parent') == '')) {
|
||||
|
||||
$pages->updateWhere('[parent="'.Request::get('name').'"]', array('parent' => Text::translitIt(trim(Request::post('page_name')))));
|
||||
|
||||
if ($pages->updateWhere('[slug="'.Request::get('name').'"]',
|
||||
array('slug' => Security::safeName(Request::post('page_name'), '-', true),
|
||||
'template' => Request::post('templates'),
|
||||
'parent' => $parent_page,
|
||||
'title' => Request::post('page_title'),
|
||||
'description' => Request::post('page_description'),
|
||||
'keywords' => Request::post('page_keywords'),
|
||||
'robots_index' => $robots_index,
|
||||
'robots_follow'=> $robots_follow,
|
||||
'status' => Request::post('status'),
|
||||
'date' => $date,
|
||||
'author' => $author))) {
|
||||
|
||||
File::setContent(STORAGE . DS . 'pages' . DS . Request::post('page_id') . '.page.txt', XML::safe(Request::post('editor')));
|
||||
Notification::set('success', __('Your changes to the page <i>:page</i> have been saved.', 'pages', array(':page' => Security::safeName(Request::post('page_title'), '-', true))));
|
||||
}
|
||||
|
||||
// Run edit extra actions
|
||||
Action::run('admin_pages_action_edit');
|
||||
|
||||
// Run add extra actions
|
||||
Action::run('admin_pages_action_add');
|
||||
|
||||
// Redirect
|
||||
if (Request::post('add_page_and_exit')) {
|
||||
Request::redirect('index.php?id=pages');
|
||||
} else {
|
||||
Request::redirect('index.php?id=pages&action=edit_page&name='.Security::safeName(Request::post('page_name'), '-', true));
|
||||
}
|
||||
} else {
|
||||
|
||||
if ($pages->updateWhere('[slug="'.Request::get('name').'"]',
|
||||
array('slug' => Security::safeName(Request::post('page_name'), '-', true),
|
||||
'template' => Request::post('templates'),
|
||||
'parent' => $parent_page,
|
||||
'title' => Request::post('page_title'),
|
||||
'description' => Request::post('page_description'),
|
||||
'keywords' => Request::post('page_keywords'),
|
||||
'robots_index' => $robots_index,
|
||||
'robots_follow'=> $robots_follow,
|
||||
'status' => Request::post('status'),
|
||||
'date' => $date,
|
||||
'author' => $author))) {
|
||||
|
||||
File::setContent(STORAGE . DS . 'pages' . DS . Request::post('page_id') . '.page.txt', XML::safe(Request::post('editor')));
|
||||
Notification::set('success', __('Your changes to the page <i>:page</i> have been saved.', 'pages', array(':page' => Security::safeName(Request::post('page_title'), '-', true))));
|
||||
}
|
||||
|
||||
// Run edit extra actions
|
||||
Action::run('admin_pages_action_edit');
|
||||
}
|
||||
|
||||
} else { die('csrf detected!'); }
|
||||
// Redirect
|
||||
if (Request::post('edit_page_and_exit')) {
|
||||
Request::redirect('index.php?id=pages');
|
||||
} else {
|
||||
Request::redirect('index.php?id=pages&action=edit_page&name='.Security::safeName(Request::post('page_name'), '-', true));
|
||||
}
|
||||
}
|
||||
|
||||
} else { die('csrf detected!'); }
|
||||
}
|
||||
|
||||
|
||||
// Get all pages
|
||||
$pages_list = $pages->select();
|
||||
$pages_array[] = '-none-';
|
||||
// Foreach pages find page whithout parent
|
||||
foreach ($pages_list as $page) {
|
||||
if (isset($page['parent'])) {
|
||||
$c_p = $page['parent'];
|
||||
} else {
|
||||
$c_p = '';
|
||||
}
|
||||
|
||||
// Get all pages
|
||||
$pages_list = $pages->select('[slug!="error404" and parent=""]');
|
||||
$pages_array[] = '-none-';
|
||||
foreach ($pages_list as $page) {
|
||||
$pages_array[$page['slug']] = $page['title'];
|
||||
if ($c_p == '') {
|
||||
// error404 is system "constant" and no child for it
|
||||
if ($page['slug'] !== 'error404' && $page['slug'] !== Request::get('name')) {
|
||||
$pages_array[$page['slug']] = $page['title'];
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Get all templates
|
||||
$templates_list = File::scan($templates_path, '.template.php');
|
||||
foreach ($templates_list as $file) {
|
||||
$templates_array[basename($file, '.template.php')] = basename($file, '.template.php');
|
||||
}
|
||||
|
||||
// Get all templates
|
||||
$templates_list = File::scan($templates_path,'.template.php');
|
||||
foreach ($templates_list as $file) {
|
||||
$templates_array[basename($file,'.template.php')] = basename($file, '.template.php');
|
||||
}
|
||||
|
||||
// Save fields
|
||||
if (Request::post('page_name')) $post_name = Request::post('page_name'); else $post_name = '';
|
||||
if (Request::post('page_title')) $post_title = Request::post('page_title'); else $post_title = '';
|
||||
if (Request::post('page_keywords')) $post_keywords = Request::post('page_keywords'); else $post_keywords = '';
|
||||
if (Request::post('page_description')) $post_description = Request::post('page_description'); else $post_description = '';
|
||||
if (Request::post('editor')) $post_content = Request::post('editor'); else $post_content = '';
|
||||
if (Request::post('templates')) $post_template = Request::post('templates'); else $post_template = 'index';
|
||||
if (Request::post('pages')) $parent_page = Request::post('pages'); else $parent_page = '';
|
||||
if (Request::post('robots_index')) $post_robots_index = true; else $post_robots_index = false;
|
||||
if (Request::post('robots_follow')) $post_robots_follow = true; else $post_robots_follow = false;
|
||||
//--------------
|
||||
|
||||
$page = $pages->select('[slug="'.Request::get('name').'"]', null);
|
||||
|
||||
if ($page) {
|
||||
|
||||
$page_content = File::getContent(STORAGE . DS . 'pages' . DS . $page['id'] . '.page.txt');
|
||||
|
||||
// Safe fields or load fields
|
||||
if (Request::post('page_name')) $slug_to_edit = Request::post('page_name'); else $slug_to_edit = $page['slug'];
|
||||
if (Request::post('page_title')) $title_to_edit = Request::post('page_title'); else $title_to_edit = $page['title'];
|
||||
if (Request::post('page_description')) $description_to_edit = Request::post('page_description'); else $description_to_edit = $page['description'];
|
||||
if (Request::post('page_keywords')) $keywords_to_edit = Request::post('page_keywords'); else $keywords_to_edit = $page['keywords'];
|
||||
if (Request::post('editor')) $to_edit = Request::post('editor'); else $to_edit = Text::toHtml($page_content);
|
||||
|
||||
if (Request::post('robots_index')) $post_robots_index = true; else if ($page['robots_index'] == 'noindex') $post_robots_index = true; else $post_robots_index = false;
|
||||
if (Request::post('robots_follow')) $post_robots_follow = true; else if ($page['robots_follow'] == 'nofollow') $post_robots_follow = true; else $post_robots_follow = false;
|
||||
|
||||
if (Request::post('pages')) {
|
||||
// Get pages parent
|
||||
if (post('pages') == '-none-') {
|
||||
$parent_page = '';
|
||||
} else {
|
||||
$parent_page = Request::post('pages');
|
||||
}
|
||||
// Save field
|
||||
$parent_page = Request::post('pages');
|
||||
} else {
|
||||
$parent_page = $page['parent'];
|
||||
}
|
||||
if (Request::post('templates')) $template = Request::post('templates'); else $template = $page['template'];
|
||||
if (Request::post('status')) $status = Request::post('status'); else $status = $page['status'];
|
||||
|
||||
// Generate date
|
||||
$date = Date::format(time(), 'Y-m-d H:i:s');
|
||||
|
||||
// Set Tabs State - page
|
||||
Notification::setNow('page', 'page');
|
||||
|
||||
Notification::setNow('page', 'page');
|
||||
|
||||
// Display view
|
||||
View::factory('box/pages/views/backend/add')
|
||||
->assign('post_name', $post_name)
|
||||
->assign('post_title', $post_title)
|
||||
->assign('post_description', $post_description)
|
||||
->assign('post_keywords', $post_keywords)
|
||||
->assign('post_content', $post_content)
|
||||
View::factory('box/pages/views/backend/edit')
|
||||
->assign('slug_to_edit', $slug_to_edit)
|
||||
->assign('title_to_edit', $title_to_edit)
|
||||
->assign('description_to_edit', $description_to_edit)
|
||||
->assign('keywords_to_edit', $keywords_to_edit)
|
||||
->assign('page', $page)
|
||||
->assign('to_edit', $to_edit)
|
||||
->assign('pages_array', $pages_array)
|
||||
->assign('parent_page', $parent_page)
|
||||
->assign('templates_array', $templates_array)
|
||||
->assign('post_template', $post_template)
|
||||
->assign('template', $template)
|
||||
->assign('status_array', $status_array)
|
||||
->assign('date', $date)
|
||||
->assign('status', $status)
|
||||
->assign('date', $date)
|
||||
->assign('post_robots_index', $post_robots_index)
|
||||
->assign('post_robots_follow', $post_robots_follow)
|
||||
->assign('post_robots_follow', $post_robots_follow)
|
||||
->assign('errors', $errors)
|
||||
->display();
|
||||
|
||||
break;
|
||||
}
|
||||
|
||||
break;
|
||||
|
||||
// Edit page
|
||||
// -------------------------------------
|
||||
case "edit_page":
|
||||
|
||||
if (Request::post('edit_page') || Request::post('edit_page_and_exit')) {
|
||||
|
||||
if (Security::check(Request::post('csrf'))) {
|
||||
|
||||
// Get pages parent
|
||||
if (Request::post('pages') == '0') {
|
||||
$parent_page = '';
|
||||
} else {
|
||||
$parent_page = Request::post('pages');
|
||||
}
|
||||
// Save field
|
||||
$post_parent = Request::post('pages');
|
||||
|
||||
|
||||
// Validate
|
||||
//--------------
|
||||
if (trim(Request::post('page_name')) == '') $errors['pages_empty_name'] = __('This field should not be empty', 'pages');
|
||||
|
||||
$_page = $pages->select('[slug="'.Security::safeName(Request::post('page_name'), '-', true).'"]');
|
||||
|
||||
if ((count($_page) != 0) and (Security::safeName(Request::post('page_old_name'), '-', true) !== Security::safeName(Request::post('page_name'), '-', true))) $errors['pages_exists'] = __('This page already exists', 'pages');
|
||||
|
||||
if (trim(Request::post('page_title')) == '') $errors['pages_empty_title'] = __('This field should not be empty', 'pages');
|
||||
|
||||
// Save fields
|
||||
if (Request::post('page_name')) $post_name = Request::post('page_name'); else $post_name = '';
|
||||
if (Request::post('page_title')) $post_title = Request::post('page_title'); else $post_title = '';
|
||||
if (Request::post('page_keywords')) $post_keywords = Request::post('page_keywords'); else $post_keywords = '';
|
||||
if (Request::post('page_description')) $post_description = Request::post('page_description'); else $post_description = '';
|
||||
if (Request::post('editor')) $post_content = Request::post('editor'); else $post_content = '';
|
||||
if (Request::post('templates')) $post_template = Request::post('templates'); else $post_template = 'index';
|
||||
if (Request::post('robots_index')) $post_robots_index = true; else $post_robots_index = false;
|
||||
if (Request::post('robots_follow')) $post_robots_follow = true; else $post_robots_follow = false;
|
||||
//--------------
|
||||
|
||||
// Generate date
|
||||
$date = mktime(Request::post('hour'),
|
||||
Request::post('minute'),
|
||||
Request::post('second'),
|
||||
Request::post('month'),
|
||||
Request::post('day'),
|
||||
Request::post('year'));
|
||||
|
||||
if (Request::post('robots_index')) $robots_index = 'noindex'; else $robots_index = 'index';
|
||||
if (Request::post('robots_follow')) $robots_follow = 'nofollow'; else $robots_follow = 'follow';
|
||||
|
||||
if (count($errors) == 0) {
|
||||
|
||||
// Update parents in all childrens
|
||||
if ((Security::safeName(Request::post('page_name'), '-', true)) !== (Security::safeName(Request::post('page_old_name'), '-', true)) and (Request::post('old_parent') == '')) {
|
||||
|
||||
$pages->updateWhere('[parent="'.Request::get('name').'"]', array('parent' => Text::translitIt(trim(Request::post('page_name')))));
|
||||
|
||||
if ($pages->updateWhere('[slug="'.Request::get('name').'"]',
|
||||
array('slug' => Security::safeName(Request::post('page_name'), '-', true),
|
||||
'template' => Request::post('templates'),
|
||||
'parent' => $parent_page,
|
||||
'title' => Request::post('page_title'),
|
||||
'description' => Request::post('page_description'),
|
||||
'keywords' => Request::post('page_keywords'),
|
||||
'robots_index' => $robots_index,
|
||||
'robots_follow'=> $robots_follow,
|
||||
'status' => Request::post('status'),
|
||||
'date' => $date,
|
||||
'author' => $author))) {
|
||||
|
||||
File::setContent(STORAGE . DS . 'pages' . DS . Request::post('page_id') . '.page.txt', XML::safe(Request::post('editor')));
|
||||
Notification::set('success', __('Your changes to the page <i>:page</i> have been saved.', 'pages', array(':page' => Security::safeName(Request::post('page_title'), '-', true))));
|
||||
}
|
||||
|
||||
// Run edit extra actions
|
||||
Action::run('admin_pages_action_edit');
|
||||
|
||||
} else {
|
||||
|
||||
if ($pages->updateWhere('[slug="'.Request::get('name').'"]',
|
||||
array('slug' => Security::safeName(Request::post('page_name'), '-', true),
|
||||
'template' => Request::post('templates'),
|
||||
'parent' => $parent_page,
|
||||
'title' => Request::post('page_title'),
|
||||
'description' => Request::post('page_description'),
|
||||
'keywords' => Request::post('page_keywords'),
|
||||
'robots_index' => $robots_index,
|
||||
'robots_follow'=> $robots_follow,
|
||||
'status' => Request::post('status'),
|
||||
'date' => $date,
|
||||
'author' => $author))) {
|
||||
|
||||
File::setContent(STORAGE . DS . 'pages' . DS . Request::post('page_id') . '.page.txt', XML::safe(Request::post('editor')));
|
||||
Notification::set('success', __('Your changes to the page <i>:page</i> have been saved.', 'pages', array(':page' => Security::safeName(Request::post('page_title'), '-', true))));
|
||||
}
|
||||
|
||||
// Run edit extra actions
|
||||
Action::run('admin_pages_action_edit');
|
||||
}
|
||||
|
||||
// Redirect
|
||||
if (Request::post('edit_page_and_exit')) {
|
||||
Request::redirect('index.php?id=pages');
|
||||
} else {
|
||||
Request::redirect('index.php?id=pages&action=edit_page&name='.Security::safeName(Request::post('page_name'), '-', true));
|
||||
}
|
||||
}
|
||||
|
||||
} else { die('csrf detected!'); }
|
||||
}
|
||||
|
||||
|
||||
// Get all pages
|
||||
$pages_list = $pages->select();
|
||||
$pages_array[] = '-none-';
|
||||
// Foreach pages find page whithout parent
|
||||
foreach ($pages_list as $page) {
|
||||
if (isset($page['parent'])) {
|
||||
$c_p = $page['parent'];
|
||||
} else {
|
||||
$c_p = '';
|
||||
}
|
||||
if ($c_p == '') {
|
||||
// error404 is system "constant" and no child for it
|
||||
if ($page['slug'] !== 'error404' && $page['slug'] !== Request::get('name')) {
|
||||
$pages_array[$page['slug']] = $page['title'];
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// Get all templates
|
||||
$templates_list = File::scan($templates_path,'.template.php');
|
||||
foreach ($templates_list as $file) {
|
||||
$templates_array[basename($file,'.template.php')] = basename($file, '.template.php');
|
||||
}
|
||||
|
||||
|
||||
$page = $pages->select('[slug="'.Request::get('name').'"]', null);
|
||||
|
||||
if ($page) {
|
||||
|
||||
$page_content = File::getContent(STORAGE . DS . 'pages' . DS . $page['id'] . '.page.txt');
|
||||
|
||||
// Safe fields or load fields
|
||||
if (Request::post('page_name')) $slug_to_edit = Request::post('page_name'); else $slug_to_edit = $page['slug'];
|
||||
if (Request::post('page_title')) $title_to_edit = Request::post('page_title'); else $title_to_edit = $page['title'];
|
||||
if (Request::post('page_description')) $description_to_edit = Request::post('page_description'); else $description_to_edit = $page['description'];
|
||||
if (Request::post('page_keywords')) $keywords_to_edit = Request::post('page_keywords'); else $keywords_to_edit = $page['keywords'];
|
||||
if (Request::post('editor')) $to_edit = Request::post('editor'); else $to_edit = Text::toHtml($page_content);
|
||||
|
||||
if (Request::post('robots_index')) $post_robots_index = true; else if ($page['robots_index'] == 'noindex') $post_robots_index = true; else $post_robots_index = false;
|
||||
if (Request::post('robots_follow')) $post_robots_follow = true; else if ($page['robots_follow'] == 'nofollow') $post_robots_follow = true; else $post_robots_follow = false;
|
||||
|
||||
if (Request::post('pages')) {
|
||||
// Get pages parent
|
||||
if (post('pages') == '-none-') {
|
||||
$parent_page = '';
|
||||
} else {
|
||||
$parent_page = Request::post('pages');
|
||||
}
|
||||
// Save field
|
||||
$parent_page = Request::post('pages');
|
||||
} else {
|
||||
$parent_page = $page['parent'];
|
||||
}
|
||||
if (Request::post('templates')) $template = Request::post('templates'); else $template = $page['template'];
|
||||
if (Request::post('status')) $status = Request::post('status'); else $status = $page['status'];
|
||||
|
||||
// Generate date
|
||||
$date = Date::format(time(), 'Y-m-d H:i:s');
|
||||
|
||||
Notification::setNow('page', 'page');
|
||||
|
||||
// Display view
|
||||
View::factory('box/pages/views/backend/edit')
|
||||
->assign('slug_to_edit', $slug_to_edit)
|
||||
->assign('title_to_edit', $title_to_edit)
|
||||
->assign('description_to_edit', $description_to_edit)
|
||||
->assign('keywords_to_edit', $keywords_to_edit)
|
||||
->assign('page', $page)
|
||||
->assign('to_edit', $to_edit)
|
||||
->assign('pages_array', $pages_array)
|
||||
->assign('parent_page', $parent_page)
|
||||
->assign('templates_array', $templates_array)
|
||||
->assign('template', $template)
|
||||
->assign('status_array', $status_array)
|
||||
->assign('status', $status)
|
||||
->assign('date', $date)
|
||||
->assign('post_robots_index', $post_robots_index)
|
||||
->assign('post_robots_follow', $post_robots_follow)
|
||||
->assign('errors', $errors)
|
||||
->display();
|
||||
}
|
||||
|
||||
break;
|
||||
|
||||
// Delete page
|
||||
// -------------------------------------
|
||||
case "delete_page":
|
||||
|
||||
// Error 404 page can not be removed
|
||||
if (Request::get('name') !== 'error404') {
|
||||
// Delete page
|
||||
// -------------------------------------
|
||||
case "delete_page":
|
||||
|
||||
// Get page title, delete page and update <parent> fields
|
||||
$page = $pages->select('[slug="'.Request::get('name').'"]', null);
|
||||
|
||||
if ($pages->deleteWhere('[slug="'.Request::get('name').'" ]')) {
|
||||
$pages->updateWhere('[parent="'.Request::get('name').'"]', array('parent' => ''));
|
||||
File::delete(STORAGE . DS . 'pages' . DS . $page['id'] . '.page.txt');
|
||||
Notification::set('success', __('Page <i>:page</i> deleted', 'pages', array(':page' => Html::toText($page['title']))));
|
||||
}
|
||||
|
||||
// Run delete extra actions
|
||||
Action::run('admin_pages_action_delete');
|
||||
|
||||
// Redirect
|
||||
Request::redirect('index.php?id=pages');
|
||||
// Error 404 page can not be removed
|
||||
if (Request::get('name') !== 'error404') {
|
||||
|
||||
// Get page title, delete page and update <parent> fields
|
||||
$page = $pages->select('[slug="'.Request::get('name').'"]', null);
|
||||
|
||||
if ($pages->deleteWhere('[slug="'.Request::get('name').'" ]')) {
|
||||
$pages->updateWhere('[parent="'.Request::get('name').'"]', array('parent' => ''));
|
||||
File::delete(STORAGE . DS . 'pages' . DS . $page['id'] . '.page.txt');
|
||||
Notification::set('success', __('Page <i>:page</i> deleted', 'pages', array(':page' => Html::toText($page['title']))));
|
||||
}
|
||||
|
||||
break;
|
||||
}
|
||||
|
||||
// Its mean that you can add your own actions for this plugin
|
||||
Action::run('admin_pages_extra_actions');
|
||||
// Run delete extra actions
|
||||
Action::run('admin_pages_action_delete');
|
||||
|
||||
} else { // Load main template
|
||||
|
||||
|
||||
$pages_list = $pages->select(null, 'all', null, array('slug', 'title', 'status', 'date', 'author', 'parent'));
|
||||
|
||||
$pages_array = array();
|
||||
|
||||
$count = 0;
|
||||
foreach ($pages_list as $page) {
|
||||
|
||||
$pages_array[$count]['title'] = $page['title'];
|
||||
$pages_array[$count]['parent'] = $page['parent'];
|
||||
$pages_array[$count]['status'] = $status_array[$page['status']];
|
||||
$pages_array[$count]['date'] = $page['date'];
|
||||
$pages_array[$count]['author'] = $page['author'];
|
||||
$pages_array[$count]['slug'] = $page['slug'];
|
||||
|
||||
if (isset($page['parent'])) {
|
||||
$c_p = $page['parent'];
|
||||
} else {
|
||||
$c_p = '';
|
||||
// Redirect
|
||||
Request::redirect('index.php?id=pages');
|
||||
}
|
||||
|
||||
if ($c_p != '') {
|
||||
$_page = $pages->select('[slug="'.$page['parent'].'"]', null);
|
||||
|
||||
if (isset($_page['title'])) {
|
||||
$_title = $_page['title'];
|
||||
} else {
|
||||
$_title = '';
|
||||
}
|
||||
$pages_array[$count]['sort'] = $_title . ' ' . $page['title'];
|
||||
} else {
|
||||
$pages_array[$count]['sort'] = $page['title'];
|
||||
}
|
||||
$_title = '';
|
||||
$count++;
|
||||
}
|
||||
|
||||
// Sort pages
|
||||
$pages = Arr::subvalSort($pages_array, 'sort');
|
||||
|
||||
// Display view
|
||||
View::factory('box/pages/views/backend/index')
|
||||
->assign('pages', $pages)
|
||||
->assign('site_url', $site_url)
|
||||
->display();
|
||||
break;
|
||||
}
|
||||
|
||||
|
||||
// Its mean that you can add your own actions for this plugin
|
||||
Action::run('admin_pages_extra_actions');
|
||||
|
||||
} else {
|
||||
|
||||
// Index action
|
||||
// -------------------------------------
|
||||
|
||||
// Init vars
|
||||
$pages_array = array();
|
||||
$count = 0;
|
||||
|
||||
// Get pages
|
||||
$pages_list = $pages->select(null, 'all', null, array('slug', 'title', 'status', 'date', 'author', 'parent'));
|
||||
|
||||
// Loop
|
||||
foreach ($pages_list as $page) {
|
||||
|
||||
$pages_array[$count]['title'] = $page['title'];
|
||||
$pages_array[$count]['parent'] = $page['parent'];
|
||||
$pages_array[$count]['status'] = $status_array[$page['status']];
|
||||
$pages_array[$count]['date'] = $page['date'];
|
||||
$pages_array[$count]['author'] = $page['author'];
|
||||
$pages_array[$count]['slug'] = $page['slug'];
|
||||
|
||||
if (isset($page['parent'])) {
|
||||
$c_p = $page['parent'];
|
||||
} else {
|
||||
$c_p = '';
|
||||
}
|
||||
|
||||
if ($c_p != '') {
|
||||
|
||||
$_page = $pages->select('[slug="'.$page['parent'].'"]', null);
|
||||
|
||||
if (isset($_page['title'])) {
|
||||
$_title = $_page['title'];
|
||||
} else {
|
||||
$_title = '';
|
||||
}
|
||||
|
||||
$pages_array[$count]['sort'] = $_title . ' ' . $page['title'];
|
||||
|
||||
} else {
|
||||
|
||||
$pages_array[$count]['sort'] = $page['title'];
|
||||
|
||||
}
|
||||
|
||||
$_title = '';
|
||||
$count++;
|
||||
}
|
||||
|
||||
// Sort pages
|
||||
$pages = Arr::subvalSort($pages_array, 'sort');
|
||||
|
||||
// Display view
|
||||
View::factory('box/pages/views/backend/index')
|
||||
->assign('pages', $pages)
|
||||
->assign('site_url', $site_url)
|
||||
->display();
|
||||
}
|
||||
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user