Changeset 9261 for extensions/AdditionalPages/admin/add_page.inc.php
- Timestamp:
- Feb 17, 2011, 4:27:09 PM (13 years ago)
- File:
-
- 1 moved
Legend:
- Unmodified
- Added
- Removed
-
extensions/AdditionalPages/admin/add_page.inc.php
r8131 r9261 2 2 3 3 if (!defined('PHPWG_ROOT_PATH')) die('Hacking attempt!'); 4 load_language('plugin.lang', AP_PATH); 5 $ap_conf = explode(',' , $conf['additional_pages']); 4 6 5 $edited_page = array(); 6 $edited_page['id'] = 0; 7 $edited_page['homepage'] = false; 7 8 $page_title = l10n('ap_create'); 8 9 9 if (isset($_GET['saved']) and isset($_GET['edit'])) 10 { 11 array_push($page['infos'], sprintf(l10n('ap_saved_page') , $_GET['edit'])); 12 } 13 14 // Suppression 15 if (isset($_POST['delete']) and isset($_GET['edit'])) 16 { 17 pwg_query('DELETE FROM ' . ADD_PAGES_TABLE . ' WHERE id = ' . $_GET['edit'] . ';'); 18 array_push($page['infos'], l10n('ap_deleted_page')); 19 @unlink(AP_PATH . 'backup/' . $_GET['edit'] . '.txt'); 20 return; 21 } 22 23 // Enregistrement 24 if (isset($_POST['save'])) 25 { 26 $group_access = (!empty($_POST['groups']) ? implode(',', $_POST['groups']) : ''); 27 $user_access = (!empty($_POST['users']) ? implode(',', $_POST['users']) : ''); 28 if (empty($_POST['name'])) 29 { 30 array_push($page['errors'], l10n('ap_no_name')); 31 $edited_page['title'] = ''; 32 $edited_page['pos'] = $_POST['pos']; 33 $edited_page['text'] = stripslashes($_POST['ap_content']); 34 $edited_page['group'] = (!empty($_POST['groups']) ? $_POST['groups'] : array()); 35 $edited_page['user'] = (!empty($_POST['users']) ? $_POST['users'] : array()); 36 } 37 else 38 { 39 $PageTitle = $_POST['name']; 40 if (!empty($group_access)) 41 { 42 $PageTitle .= '/group_id=' . $group_access ; 43 } 44 if ($ap_conf[7] == 'on') 45 { 46 $PageTitle .= '/user_id=' . $user_access ; 47 } 48 if (isset($_GET['edit'])) 49 { 50 $next_element_id = $_GET['edit']; 51 pwg_query('DELETE FROM ' . ADD_PAGES_TABLE . ' WHERE id = ' . $_GET['edit'] . ';'); 52 } 53 else 54 { 55 $q = 'SELECT IF(MAX(id)+1 IS NULL, 1, MAX(id)+1) AS next_element_id FROM ' . ADD_PAGES_TABLE . ' ;'; 56 list($next_element_id) = mysql_fetch_array(pwg_query($q)); 57 } 58 if ($_POST['pos'] == '') $_POST['pos'] = 'NULL'; 59 $q = 'INSERT INTO ' . ADD_PAGES_TABLE . ' ( id , pos , lang , title , text ) 60 VALUES (' . $next_element_id . ' , ' . $_POST['pos'] . ' , "' . $_POST['lang'] . '" , "' . $PageTitle . '" , "' . $_POST['ap_content'] . '");'; 61 pwg_query($q); 62 63 // Enregistrement du fichier de sauvegarde 64 $sav_file = @fopen(AP_PATH . 'backup/' . $next_element_id . '.txt', "w"); 65 @fwrite($sav_file, "Title: " . $_POST['name'] . " 66 Position: " . $_POST['pos'] . " 67 Language: " . $_POST['lang'] . " 68 69 " . $_POST['ap_content']); 70 @fclose($sav_file); 71 72 if (isset($ap_conf[4]) and $ap_conf[4] == 'on') 73 { 74 redirect(get_root_url() . 'index.php?/additional_page/' . $next_element_id); 75 } 76 else 77 { 78 redirect(get_root_url() . 'admin.php?page=plugin§ion=' . AP_DIR . '%2Fadmin%2Fadd_page.php&saved=1&edit=' . $next_element_id); 79 } 80 } 81 } 82 83 // Chargement des données 84 if (isset($_GET['edit'])) 85 { 86 $q = 'SELECT id , pos , lang , title , text 87 FROM ' . ADD_PAGES_TABLE . ' 88 WHERE id = ' . $_GET['edit'] . ';'; 89 $edited_page = mysql_fetch_assoc(pwg_query($q)); 90 $page_title = l10n('ap_modify'); 91 // Utilisateurs autorisés 92 if (strpos($edited_page['title'] , '/user_id=')) 93 { 94 $array = explode('/user_id=' , $edited_page['title']); 95 $edited_page['title'] = $array[0]; 96 $edited_page['user'] = explode(',', $array[1]); 97 } 98 // Groupes autorisés 99 if (strpos($edited_page['title'] , '/group_id=')) 100 { 101 $array = explode('/group_id=' , $edited_page['title']); 102 $edited_page['title'] = $array[0]; 103 $edited_page['group'] = explode(',', $array[1]); 104 } 105 // Lien de suppression 106 $template->assign('delete', true); 107 } 108 109 // Selection des langues 110 $options['ALL'] = l10n('ap_all_lang'); 111 $selected = 'ALL'; 112 foreach (get_languages() as $language_code => $language_name) 113 { 114 $options[$language_code] = $language_name; 115 if (isset($edited_page['lang']) and $edited_page['lang'] == $language_code) 116 { 117 $selected = $language_code; 118 } 119 } 120 $template->assign('lang', array( 121 'OPTIONS' => $options, 122 'SELECTED' => $selected)); 123 124 // Selection des groupes 125 if (isset($ap_conf[6]) and $ap_conf[6] == 'on') 126 { 127 include_once(AP_PATH . 'admin/functions_groups.php'); 128 $template->assign('GROUPSELECTION', get_html_groups_selection(get_all_groups(), 'groups', (!empty($edited_page['group']) ? $edited_page['group'] : array()))); 129 } 130 131 // Selection des utilisateurs 132 if (isset($ap_conf[7]) and $ap_conf[7] == 'on') 133 { 134 $selected_users = (isset($edited_page['user']) ? $edited_page['user'] : array('guest', 'generic', 'normal')); 135 $template->assign('user_perm', array( 136 'GUEST' => (in_array('guest', $selected_users) ? 'checked="checked"' : ''), 137 'GENERIC' => (in_array('generic', $selected_users) ? 'checked="checked"' : ''), 138 'NORMAL' => (in_array('normal', $selected_users) ? 'checked="checked"' : ''))); 139 } 140 141 // Chargement des données pour l'édition 142 if (!empty($edited_page)) 143 { 144 $template->assign(array( 145 'NAME' => $edited_page['title'], 146 'POS' => $edited_page['pos'], 147 'CONTENT' => $edited_page['text'])); 148 } 149 150 // Parametrage du template 151 $template->assign('AP_TITLE', $page_title); 152 153 $template->set_filename('plugin_admin_content', dirname(__FILE__) . '/add_page.tpl'); 154 $template->assign_var_from_handle('ADMIN_CONTENT', 'plugin_admin_content'); 10 include(AP_PATH.'admin/page_form.inc.php'); 155 11 156 12 ?>
Note: See TracChangeset
for help on using the changeset viewer.