3 class mw_pages extends mw_plugin{
9 function description($env){
10 return "Pour ajouter des pages, avec un éditeur dans l'administration du site";
14 $env->set_link("plugins/admin/mw_pages", $env->url("pages/admin"), "éditer les pages");
15 $env->set_link("admin/pages", $env->url("pages/admin"), "Pages", 40);
19 $pages = $data->pages(
23 "order_by" => "position",
29 foreach($pages["list"] as $id_page => $page){
31 "menu_top/mw_page_".$id_page,
32 $env->url("pages/view/page", array("id" => $id_page)),
41 function enable($env){
42 $plugins_pages_start_id = $env->config("plugins_pages_start_id");
43 if($plugins_pages_start_id){
46 $data->set_config("start_action", "pages/view/page")
47 && $data->set_config("start_action_params", @serialize(array("id" => $plugins_pages_start_id)))
56 function disable($env){
57 $start_action = $env->config("start_action");
58 if($start_action == "pages/view/page"){
61 $data->set_config("start_action", "")
62 && $data->set_config("start_action_params", "")
71 // ---------------------------------------------------------------------------------
75 function install($env){
76 if($env->bdd("sgbd") == "xml") return $this->install_xml($env);
77 if($env->bdd("sgbd") == "sqlite") return $this->install_sqlite($env);
78 if($env->bdd("sgbd") == "mysql") return $this->install_mysql($env);
81 function install_xml($env){
83 $sgbd = $data->sgbd();
84 $EXISTS = $sgbd->data_exists("pages");
86 return "impossible de savoir si la table #--pages existe";
89 return "la table #--pages existe deja";
91 if(!$sgbd->create_data("pages")){
92 return "imposible de creer la table #--pages";
94 if(!$sgbd->add_data("action_status", array("action" => "pages/admin", "id_status" => "1"))){
95 $sgbd->remove_data("pages");
96 return "impossible d'ajouter un statut pour l'action pages/admin";
101 function install_sqlite($env){
102 $data = $env->data();
103 $sgbd = $data->sgbd();
104 $EXISTS = $sgbd->table_exists("#--pages");
106 return "impossible de savoir si la table #--pages existe";
109 return "la table #--pages existe deja";
112 "CREATE TABLE #--pages"
113 ."( id INTEGER NOT NULL PRIMARY KEY"
114 .", id_parent INTEGER NULL"
115 .", title VARCHAR NULL"
116 .", content TEXT NULL"
117 .", date_creation TEXT NOT NULL"
118 .", user_creation INTEGER NOT NULL"
119 .", date_last_update TEXT NOT NULL"
120 .", user_last_update INTEGER NOT NULL"
121 .", enabled INTEGER NOT NULL DEFAULT 1"
122 .", position INTEGER NOT NULL DEFAULT 0"
124 if(!$sgbd->query($sql)){
125 return "imposible de creer la table #--pages";
127 if(!$sgbd->query("INSERT INTO #--action_status(action, id_status) VALUES('pages/admin', 1)")){
128 $sgbd->query("DROP TABLE \"main\".\"#--pages\"");
129 return "impossible d'ajouter un statut pour l'action pages/admin";
134 function install_mysql($env){
135 $data = $env->data();
136 $sgbd = $data->sgbd();
137 $EXISTS = $sgbd->table_exists("#--pages");
139 return "impossible de savoir si la table #--pages existe";
142 return "la table #--pages existe deja";
145 "CREATE TABLE #--pages"
146 ."( id INT(11) NOT NULL AUTO_INCREMENT PRIMARY KEY"
147 .", id_parent INT(11) NULL"
148 .", title VARCHAR(255) NULL"
149 .", content TEXT NULL"
150 .", date_creation DATETIME NOT NULL"
151 .", user_creation INT(11) NOT NULL"
152 .", date_last_update DATETIME NOT NULL"
153 .", user_last_update INT(11) NOT NULL"
154 .", enabled TINYINT NOT NULL DEFAULT '1'"
155 .", position INT(11) NOT NULL DEFAULT '0'"
156 .") DEFAULT CHARSET=utf8";
157 if(!$sgbd->query($sql)){
158 return "imposible de creer la table #--pages";
160 if(!$sgbd->query("INSERT INTO #--action_status(action, id_status) VALUES('pages/admin', 1)")){
161 $sgbd->query("DROP TABLE #--pages");
162 return "impossible d'ajouter un statut pour l'action pages/admin";
167 // ---------------------------------------------------------------------------------
171 function uninstall($env){
172 if($env->bdd("sgbd") == "xml") return $this->uninstall_xml($env);
173 if($env->bdd("sgbd") == "sqlite") return $this->uninstall_sqlite($env);
174 if($env->bdd("sgbd") == "mysql") return $this->uninstall_mysql($env);
177 function uninstall_xml($env){
178 $data = $env->data();
179 $sgbd = $data->sgbd();
180 if(!$this->disable($env)) return "impossible de desactiver le plugin";
181 $data->del_config("plugins_pages_start_id");
182 $EXISTS = $sgbd->data_exists("pages");
184 return "impossible de savoir si la table #--pages existe";
187 // return "la table #--pages n'existe pas";
189 elseif(!$sgbd->remove_data("pages")){
190 return "imposible de supprimer la table #--pages";
193 if($rst = $sgbd->open_data("action_status")){
194 while($v_rst = $sgbd->fetch_data($rst)){
196 if(isset($v_rst["action"]) && isset($v_rst["id"]) && $v_rst["action"] == "pages/admin"){
197 $ids[] = $v_rst["id"];
202 $sgbd->close_data($rst);
205 foreach($ids as $id){
206 $sgbd->del_data("action_status", $id);
212 function uninstall_sqlite($env){
213 $data = $env->data();
214 $sgbd = $data->sgbd();
215 if(!$this->disable($env)) return "impossible de desactiver le plugin";
216 $data->del_config("plugins_pages_start_id");
217 $EXISTS = $sgbd->table_exists("#--pages");
219 return "impossible de savoir si la table #--pages existe";
222 // return "la table #--pages n'existe pas";
224 elseif(!$sgbd->query("DROP TABLE \"main\".\"#--pages\"")){
225 return "imposible de supprimer la table #--pages";
227 $sgbd->query("DELETE FROM #--action_status WHERE action='pages/admin'");
231 function uninstall_mysql($env){
232 $data = $env->data();
233 $sgbd = $data->sgbd();
234 if(!$this->disable($env)) return "impossible de desactiver le plugin";
235 $data->del_config("plugins_pages_start_id");
236 $EXISTS = $sgbd->table_exists("#--pages");
238 return "impossible de savoir si la table #--pages existe";
241 // return "la table #--pages n'existe pas";
243 elseif(!$sgbd->query("DROP TABLE #--pages")){
244 return "imposible de supprimer la table #--pages";
246 $sgbd->query("DELETE FROM #--action_status WHERE action='pages/admin'");