source: extensions/manage_properties_photos/initadmin.php @ 32180

Last change on this file since 32180 was 32180, checked in by ddtddt, 4 years ago

[manage_properties_photos]

File size: 7.3 KB
Line 
1<?php
2// +-----------------------------------------------------------------------+
3// | Manage Properties Photos plugin for Piwigo by TEMMII                  |
4// +-----------------------------------------------------------------------+
5// | Copyright(C) 2007-2020 ddtddt               http://temmii.com/piwigo/ |
6// +-----------------------------------------------------------------------+
7// | This program is free software; you can redistribute it and/or modify  |
8// | it under the terms of the GNU General Public License as published by  |
9// | the Free Software Foundation                                          |
10// |                                                                       |
11// | This program is distributed in the hope that it will be useful, but   |
12// | WITHOUT ANY WARRANTY; without even the implied warranty of            |
13// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU      |
14// | General Public License for more details.                              |
15// |                                                                       |
16// | You should have received a copy of the GNU General Public License     |
17// | along with this program; if not, write to the Free Software           |
18// | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, |
19// | USA.                                                                  |
20// +-----------------------------------------------------------------------+
21
22//add admin menu
23add_event_handler('get_admin_plugin_menu_links', 'add_info_photo_admin_menu');
24
25function add_info_photo_admin_menu($menu){
26    load_language('plugin.lang', ADD_PROP_PHOTO_PATH);
27    $menu[] = array(
28        'NAME' => l10n('Manage properties photos'),
29        'URL' => ADD_PROP_PHOTO_ADMIN,
30    );
31     return $menu;
32}
33
34add_event_handler('tabsheet_before_select', 'aip_tabsheet_before_select',
35    EVENT_HANDLER_PRIORITY_NEUTRAL);
36
37function aip_tabsheet_before_select($sheets, $id){
38  global $template, $page;
39  if ($id == 'photo'){
40    $sheets['iap'] = array(
41      'caption' => l10n('Properties additionals'),
42      'url' => ADD_PROP_PHOTO_ADMIN.'-iap&amp;image_id='.$_GET['image_id'],
43      );
44  }
45  return $sheets;
46}
47
48//add manage by batch Manager
49add_event_handler('loc_end_element_set_global', 'MPP_loc_end_element_set_global');
50add_event_handler('element_set_global_action', 'MPP_element_set_global_action', EVENT_HANDLER_PRIORITY_NEUTRAL, 2);
51 
52function MPP_loc_end_element_set_global(){
53  global $template;
54 
55  $template->assign(array(
56  'ADD_PROP_PHOTO_PATH'=> get_root_url() . ADD_PROP_PHOTO_PATH,
57  )); 
58 
59  $q = 'SELECT 1 FROM ' . ADD_PROP_PHOTO_TABLE . ' WHERE edit=1';
60  $test = pwg_query($q);
61  $row = pwg_db_fetch_assoc($test);
62  if (!empty($row)){
63        $propertieslist = array();
64        $propertieslist2 = tab_add_info_by_photo();
65        $PAED = pwg_db_fetch_assoc(pwg_query("SELECT state FROM " . PLUGINS_TABLE . " WHERE id = 'ExtendedDescription';"));
66          if($PAED['state'] == 'active'){
67                add_event_handler('AP_render_content', 'get_user_language_desc');
68                $template->assign('useED',1);
69      }else{
70        $template->assign('useED',0);
71      }
72                $template->assign('DATADATE', date('Y-m-d').' 10:05:05');
73        while ($info_select = pwg_db_fetch_assoc($propertieslist2)){
74                $items = array(
75                        'IDINFOPHO' => $info_select['id_prop_pho'],
76                        'AIPWORDING' => trigger_change('AP_render_content',$info_select['wording']),
77                        'AIPTYP' => $info_select['Typ'],
78                );
79                if($info_select['Typ']==4||$info_select['Typ']==5){
80                        $items['AIPDATAPROP'] =  json_encode(unserialize($info_select['dataprop']));
81                }               
82                if($info_select['wording']=="**delpho**"){
83                        $items['AIPWORDING'] =l10n('Delete photo');
84                }
85                $template->append('info_select', $items);
86        }
87       
88    $template->set_filename('MMPP', realpath(ADD_PROP_PHOTO_PATH.'mmp.tpl'));
89    $template->assign('propertieslist', $propertieslist);
90    $template->append('element_set_global_plugins_actions', array(
91      'ID' => 'MPP', 
92      'NAME' => l10n('Change photos properties'), 
93      'CONTENT' => $template->parse('MMPP', true)
94        ));
95  }
96}
97 
98function MPP_element_set_global_action($action, $collection){
99  if ($action == 'MPP'){
100        global $page,$template,$prefixeTable;
101    $id_prop_pho= $_POST['IDMPP'];
102        $Typ=$_POST['invisibleTyp'];
103        if($Typ==2){
104                $data= $_POST['datadate'];
105        }else if($Typ==4){
106                $data= $_POST['dataselect'];
107        }else if($Typ==5){
108                $data= $_POST['radioselect'];
109        }else{
110                $data= $_POST['dataglob'];
111        }
112       
113  if($Typ==2){
114        if (!empty($_POST['check_MPP'])){
115          foreach ($collection as $image_id){
116                $query = 'DELETE FROM ' . $prefixeTable . 'add_properties_photos_datadate WHERE id_img=' . $image_id . ' AND id_prop_pho=' . $id_prop_pho;
117                pwg_query($query);
118      }
119    }else{
120      foreach ($collection as $image_id){
121            $q = 'SELECT 1 FROM ' . ADD_PROP_PHOTO_DATADATE_TABLE . ' WHERE id_img=' . $image_id . ' AND id_prop_pho=' . $id_prop_pho;
122        $test = pwg_query($q);
123        $row = pwg_db_fetch_assoc($test);
124        if (!empty($row)) {
125                  if ($data != '') {
126                        $query = 'UPDATE ' . $prefixeTable . 'add_properties_photos_datadate SET datadate="' . $data . '" WHERE id_img=' . $image_id . ' AND id_prop_pho=' . $id_prop_pho;
127                        pwg_query($query);
128                  }else{
129                        $query = 'DELETE FROM ' . $prefixeTable . 'add_properties_photos_datadate WHERE id_img=' . $image_id . ' AND id_prop_pho=' . $id_prop_pho;
130                        pwg_query($query);
131                  }
132        }else if ($data != ''){
133            $query = 'INSERT ' . $prefixeTable . 'add_properties_photos_datadate(id_img,id_prop_pho,datadate) VALUES (' . $image_id . ',' . $id_prop_pho . ',"' . $data . '");';
134            pwg_query($query);
135        }
136      }
137    }
138  }else{
139        if (!empty($_POST['check_MPP'])){
140          foreach ($collection as $image_id){
141                $query = 'DELETE FROM ' . $prefixeTable . 'add_properties_photos_data WHERE id_img=' . $image_id . ' AND id_prop_pho=' . $id_prop_pho;
142                pwg_query($query);
143      }
144    }else{
145      foreach ($collection as $image_id){
146            $q = 'SELECT id_img FROM ' . ADD_PROP_PHOTO_DATA_TABLE . ' WHERE id_img=' . $image_id . ' AND id_prop_pho=' . $id_prop_pho;
147        $test = pwg_query($q);
148        $row = pwg_db_fetch_assoc($test);
149        if (!empty($row)) {
150                  if ($data != '') {
151                        $query = 'UPDATE ' . $prefixeTable . 'add_properties_photos_data SET data="' . $data . '" WHERE id_img=' . $image_id . ' AND id_prop_pho=' . $id_prop_pho;
152                        pwg_query($query);
153                  }else{
154                        $query = 'DELETE FROM ' . $prefixeTable . 'add_properties_photos_data WHERE id_img=' . $image_id . ' AND id_prop_pho=' . $id_prop_pho;
155                        pwg_query($query);
156                  }
157        }else if ($data != ''){
158            $query = 'INSERT ' . $prefixeTable . 'add_properties_photos_data(id_img,id_prop_pho,data) VALUES (' . $image_id . ',' . $id_prop_pho . ',"' . $data . '");';
159            pwg_query($query);
160        }
161      }
162    }
163  }
164  }
165}
166 
167add_event_handler('loc_begin_admin_page', 'mpp_change_admin_show');
168function mpp_change_admin_show(){
169  global $template;
170  $template->set_prefilter('config', 'mpp_change_admin_show_prefilter');
171}
172
173function mpp_change_admin_show_prefilter($content, &$smarty){
174  $search = '#(<fieldset id="pictureInfoConf">).*</fieldset>#ms';
175  return preg_replace($search, '
176  <fieldset id="pictureInfoConf">
177    <legend>{\'Photo Properties\'|@translate}</legend>
178          <a href="'.ADD_PROP_PHOTO_ADMIN.'"><span class="icon-arrows-cw"></span>{\'Manage properties photos\'|@translate}</a>
179  </fieldset>
180  ', $content);
181}
Note: See TracBrowser for help on using the repository browser.