Mercurial > hg > rc1
annotate plugins/thunderbird_labels/thunderbird_labels.php @ 44:10091cdd9844
upgrade
| author | Charlie Root |
|---|---|
| date | Thu, 28 Aug 2025 10:38:39 -0400 |
| parents | 05c4c32948af |
| children | 91f005a4f7e9 |
| rev | line source |
|---|---|
| 0 | 1 <?php |
| 2 /** | |
| 3 * Thunderbird Labels Plugin for Roundcube Webmail | |
| 4 * | |
| 5 * Plugin to show the 5 Message Labels Thunderbird Email-Client provides for IMAP | |
| 6 * | |
| 7 * @version $Revision$ | |
| 8 * @author Michael Kefeder | |
| 9 * @url http://code.google.com/p/rcmail-thunderbird-labels/ | |
| 10 */ | |
| 11 class thunderbird_labels extends rcube_plugin | |
| 12 { | |
| 13 public $task = 'mail|settings'; | |
| 14 private $rc; | |
| 15 private $map; | |
| 16 | |
| 17 function init() | |
| 18 { | |
| 19 $this->rc = rcmail::get_instance(); | |
| 20 $this->load_config(); | |
| 21 $this->add_texts('localization/', false); | |
| 22 | |
| 23 $this->setCustomLabels(); | |
| 24 | |
| 25 if ($this->rc->task == 'mail') | |
| 26 { | |
| 27 # -- disable plugin when printing message | |
| 28 if ($this->rc->action == 'print') | |
| 29 return; | |
| 30 | |
| 31 if (!$this->rc->config->get('tb_label_enable')) | |
| 32 // disable plugin according to prefs | |
| 33 return; | |
| 34 | |
| 9 | 35 // how many labels? |
| 36 $max_id = $this->rc->config->get('tb_max_label'); | |
| 37 // pass 'tb_max_label', 'tb_label_enable_shortcuts' | |
| 38 // and 'tb_label_style' prefs to JS | |
| 39 $this->rc->output->set_env('tb_max_label', $max_id); | |
| 0 | 40 $this->rc->output->set_env('tb_label_enable_shortcuts', $this->rc->config->get('tb_label_enable_shortcuts')); |
| 41 $this->rc->output->set_env('tb_label_style', $this->rc->config->get('tb_label_style')); | |
| 42 | |
| 43 $this->include_script('tb_label.js'); | |
| 44 $this->add_hook('messages_list', array($this, 'read_flags')); | |
| 45 $this->add_hook('message_load', array($this, 'read_single_flags')); | |
| 46 $this->add_hook('template_object_messageheaders', array($this, 'color_headers')); | |
|
26
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
47 $this->add_hook('render_page', array($this, 'tblabelpopup')); |
| 35 | 48 $this->add_hook('message_ready', array($this, 'whiteMessage')); |
| 0 | 49 $this->include_stylesheet($this->local_skin_path() . '/tb_label.css'); |
| 50 | |
| 51 $this->name = get_class($this); | |
| 52 # -- additional TB flags | |
|
1
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
53 $this->add_tb_flags = array(); |
|
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
54 for ($i = 1; $i <= $max_id; $i++) { |
|
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
55 $this->add_tb_flags['LABEL'.$i]='$Label'.$i; |
|
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
56 } |
| 0 | 57 $this->message_tb_labels = array(); |
| 58 | |
|
26
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
59 # This builds the toolbar button, but |
|
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
60 # it's also used by the ctxtmenu initialisation |
|
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
61 # contextmenu.js:rcube_context_menu to build |
|
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
62 # the context menu, and that somehow |
|
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
63 # ends up with display: none??? |
|
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
64 # Bother, missed it, it's before this.container.show |
|
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
65 # Afeter ul.appendnd -- inside menu.show on 307 |
|
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
66 # 567? Yes -- that's calling 'hide', but overriding |
|
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
67 # doesn't fix :-( |
| 0 | 68 $this->add_button( |
| 69 array( | |
|
26
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
70 #'command' => 'plugin.thunderbird_labels.rcm_tb_label_submenu', |
|
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
71 'name' => 'tblabellink', |
|
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
72 'id' => 'tblabelpopuplink', |
| 29 | 73 'domain' => $this->ID, |
|
26
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
74 'type' => 'link', |
|
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
75 'class' => 'button tblabel', |
| 29 | 76 'label' => 'tb_label_button_label', |
| 77 'title' => 'tb_label_button_title', | |
|
26
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
78 'onclick' => "UI.toggle_popup('tblabelpopup',event);return false", |
|
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
79 'aria-haspopup' => true, |
|
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
80 'aria-expanded' => false, |
|
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
81 'aria-owns' => 'plugin.thunderbird_labels.rcm_tb_label_submenu-menu' |
|
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
82 #'classact' => 'listbutton add', |
| 0 | 83 ), |
| 84 'toolbar' | |
| 85 ); | |
|
26
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
86 |
| 0 | 87 // JS function "set_flags" => PHP function "set_flags" |
| 88 $this->register_action('plugin.thunderbird_labels.set_flags', array($this, 'set_flags')); | |
| 89 | |
| 35 | 90 #rcube::write_log('lab','set_flags registered'); |
| 0 | 91 |
| 92 if (method_exists($this, 'require_plugin') | |
| 93 && in_array('contextmenu', $this->rc->config->get('plugins')) | |
| 94 && $this->require_plugin('contextmenu') | |
| 95 && $this->rc->config->get('tb_label_enable_contextmenu')) | |
| 96 { | |
|
1
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
97 if ($this->rc->action == 'list') |
| 0 | 98 $this->add_hook('render_mailboxlist', array($this, 'show_tb_label_contextmenu')); |
| 27 | 99 #rcube::write_log('lab','ctxt: '.$this->rc->action); |
|
1
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
100 } |
|
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
101 else { |
| 27 | 102 #rcube::write_log('lab','no ctxt'); |
| 0 | 103 } |
| 104 } | |
| 105 elseif ($this->rc->task == 'settings') | |
| 106 { | |
| 107 $this->include_stylesheet($this->local_skin_path() . '/tb_label.css'); | |
| 108 $this->add_hook('preferences_list', array($this, 'prefs_list')); | |
| 109 $this->add_hook('preferences_sections_list', array($this, 'prefs_section')); | |
| 110 $this->add_hook('preferences_save', array($this, 'prefs_save')); | |
| 111 } | |
| 112 } | |
| 113 | |
| 114 private function setCustomLabels() | |
| 115 { | |
| 116 $c = $this->rc->config->get('tb_label_custom_labels'); | |
| 117 if (empty($c)) | |
| 118 { | |
| 119 // if no user specific labels, use localized strings by default | |
|
1
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
120 $max_id = $this->rc->config->get('tb_max_label'); |
| 23 | 121 $parmLabs = array(); |
|
1
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
122 $tb_flag_text = array(); |
|
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
123 for ($i = 0; $i <= $max_id; $i++) { |
| 23 | 124 $lab=$this->getText('label'.$i); |
| 125 $isParm=($lab[-1]=='1'); | |
| 126 $lab=substr($lab,0,strlen($lab)-1); | |
| 127 $tb_flag_text[$i] = $lab; | |
| 128 if ($isParm) { | |
| 129 $parmLabs[$i]=strtolower($lab); | |
| 130 } | |
|
1
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
131 } |
|
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
132 $this->rc->config->set('tb_label_custom_labels', |
| 23 | 133 $tb_flag_text); |
| 134 $this->rc->config->set('tb_label_parm_labels', | |
| 135 $parmLabs); | |
| 0 | 136 } |
| 137 // pass label strings to JS | |
| 138 $this->rc->output->set_env('tb_label_custom_labels', $this->rc->config->get('tb_label_custom_labels')); | |
| 23 | 139 $this->rc->output->set_env('tb_label_parm_labels', $this->rc->config->get('tb_label_parm_labels')); |
| 0 | 140 } |
| 141 | |
| 142 // create a section for the tb-labels Settings | |
| 143 public function prefs_section($args) | |
| 144 { | |
| 145 $args['list']['thunderbird_labels'] = array( | |
| 146 'id' => 'thunderbird_labels', | |
| 147 'section' => rcube::Q($this->gettext('tb_label_options')) | |
| 148 ); | |
| 149 | |
| 150 return $args; | |
| 151 } | |
| 152 | |
| 153 // display thunderbird-labels prefs in Roundcube Settings | |
| 154 public function prefs_list($args) | |
| 155 { | |
| 156 if ($args['section'] != 'thunderbird_labels') | |
| 157 return $args; | |
| 158 | |
| 159 $this->load_config(); | |
| 160 $dont_override = (array) $this->rc->config->get('dont_override', array()); | |
| 161 | |
| 162 $args['blocks']['tb_label'] = array(); | |
| 163 $args['blocks']['tb_label']['name'] = $this->gettext('tb_label_options'); | |
| 164 | |
| 165 $key = 'tb_label_enable'; | |
| 166 if (!in_array($key, $dont_override)) | |
| 167 { | |
| 168 $input = new html_checkbox(array( | |
| 169 'name' => $key, | |
| 170 'id' => $key, | |
| 171 'value' => 1 | |
| 172 )); | |
| 173 $content = $input->show($this->rc->config->get($key)); | |
| 174 $args['blocks']['tb_label']['options'][$key] = array( | |
| 175 'title' => $this->gettext('tb_label_enable_option'), | |
| 176 'content' => $content | |
| 177 ); | |
| 178 } | |
| 179 | |
| 180 $key = 'tb_label_enable_shortcuts'; | |
| 181 if (!in_array($key, $dont_override)) | |
| 182 { | |
| 183 $input = new html_checkbox(array( | |
| 184 'name' => $key, | |
| 185 'id' => $key, | |
| 186 'value' => 1 | |
| 187 )); | |
| 188 $content = $input->show($this->rc->config->get($key)); | |
| 189 $args['blocks']['tb_label']['options'][$key] = array( | |
| 190 'title' => $this->gettext('tb_label_enable_shortcuts_option'), | |
| 191 'content' => $content | |
| 192 ); | |
| 193 } | |
| 194 | |
| 195 $key = 'tb_label_style'; | |
| 196 if (!in_array($key, $dont_override)) | |
| 197 { | |
| 198 $select = new html_select(array( | |
| 199 'name' => $key, | |
| 200 'id' => $key | |
| 201 )); | |
| 202 $select->add(array($this->gettext('thunderbird'), $this->gettext('bullets')), array('thunderbird', 'bullets')); | |
| 203 $content = $select->show($this->rc->config->get($key)); | |
| 204 | |
| 205 $args['blocks']['tb_label']['options'][$key] = array( | |
| 206 'title' => $this->gettext('tb_label_style_option'), | |
| 207 'content' => $content | |
| 208 ); | |
| 209 } | |
| 210 | |
| 211 $key = 'tb_label_custom_labels'; | |
| 212 if (!in_array($key, $dont_override) | |
| 213 && $this->rc->config->get('tb_label_modify_labels')) | |
| 214 { | |
| 215 $old = $this->rc->config->get($key); | |
| 23 | 216 $oldParms = $this->rc->config->get('tb_label_parm_labels'); |
|
1
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
217 $max_id = $this->rc->config->get('tb_max_label'); |
|
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
218 for($i=1; $i<=$max_id; $i++) |
| 0 | 219 { |
|
19
49706603be30
begin to add UI support for parameterised labels, e.g. Dates
Charlie Root
parents:
9
diff
changeset
|
220 $oldVal = $old[$i]; |
| 23 | 221 $oparm=$oldParms[$i]?1:0; |
| 0 | 222 $input = new html_inputfield(array( |
| 223 'name' => $key.$i, | |
| 224 'id' => $key.$i, | |
| 225 'type' => 'text', | |
| 226 'autocomplete' => 'off', | |
| 23 | 227 'value' => $oldVal)); |
|
19
49706603be30
begin to add UI support for parameterised labels, e.g. Dates
Charlie Root
parents:
9
diff
changeset
|
228 $parmBox = new html_checkbox(array( |
|
49706603be30
begin to add UI support for parameterised labels, e.g. Dates
Charlie Root
parents:
9
diff
changeset
|
229 'name' => $key.$i.'parm', |
|
49706603be30
begin to add UI support for parameterised labels, e.g. Dates
Charlie Root
parents:
9
diff
changeset
|
230 'id' => $key.$i.'parm', |
|
49706603be30
begin to add UI support for parameterised labels, e.g. Dates
Charlie Root
parents:
9
diff
changeset
|
231 'value' => 1)); |
| 0 | 232 $args['blocks']['tb_label']['options'][$key.$i] = array( |
| 233 'title' => $this->gettext('tb_label_label')." ".$i, | |
|
19
49706603be30
begin to add UI support for parameterised labels, e.g. Dates
Charlie Root
parents:
9
diff
changeset
|
234 'content' => $input->show()." ".$parmBox->show($oparm) |
| 0 | 235 ); |
| 236 } | |
| 237 } | |
| 238 | |
| 239 return $args; | |
| 240 } | |
| 241 | |
| 242 // save prefs after modified in UI | |
| 243 public function prefs_save($args) | |
| 244 { | |
| 9 | 245 #rcube::write_log('lab','saving: '.print_r($args,true)); |
| 2 | 246 if ($args['section'] != 'thunderbird_labels') |
| 0 | 247 return $args; |
| 248 | |
| 249 | |
| 250 $this->load_config(); | |
| 251 $dont_override = (array) $this->rc->config->get('dont_override', array()); | |
| 252 | |
| 253 if (!in_array('tb_label_enable', $dont_override)) | |
| 254 $args['prefs']['tb_label_enable'] = rcube_utils::get_input_value('tb_label_enable', rcube_utils::INPUT_POST) ? true : false; | |
| 255 | |
| 256 if (!in_array('tb_label_enable_shortcuts', $dont_override)) | |
| 257 $args['prefs']['tb_label_enable_shortcuts'] = rcube_utils::get_input_value('tb_label_enable_shortcuts', rcube_utils::INPUT_POST) ? true : false; | |
| 258 | |
| 259 if (!in_array('tb_label_style', $dont_override)) | |
| 260 $args['prefs']['tb_label_style'] = rcube_utils::get_input_value('tb_label_style', rcube_utils::INPUT_POST); | |
| 261 | |
| 262 if (!in_array('tb_label_custom_labels', $dont_override) | |
| 263 && $this->rc->config->get('tb_label_modify_labels')) | |
| 264 { | |
|
1
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
265 $max_id = $this->rc->config->get('tb_max_label'); |
|
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
266 $tb_lab_prefs = array(); |
| 23 | 267 $tb_parm_prefs = array(); |
|
1
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
268 $tb_lab_prefs[0] = $this->gettext('label0'); |
|
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
269 for ($i = 1; $i <= $max_id; $i++) { |
| 23 | 270 $tb_lab_prefs[$i] = rcube_utils::get_input_value('tb_label_custom_labels'.$i, rcube_utils::INPUT_POST); |
| 271 if (rcube_utils::get_input_value('tb_label_custom_labels'.$i.'parm', rcube_utils::INPUT_POST)) { | |
| 272 $tb_parm_prefs[$i] = strtolower($tb_lab_prefs[$i]); | |
| 273 } | |
|
1
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
274 } |
| 2 | 275 $args['prefs']['tb_label_custom_labels'] = $tb_lab_prefs; |
| 23 | 276 $args['prefs']['tb_label_parm_labels'] = $tb_parm_prefs; |
| 0 | 277 } |
| 278 | |
| 279 return $args; | |
| 280 } | |
| 281 | |
| 282 public function show_tb_label_contextmenu($args) | |
|
26
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
283 # never called? |
| 0 | 284 { |
| 285 #$this->api->output->add_label('copymessage.copyingmessage'); | |
| 286 $li = html::tag('li', | |
| 287 array('class' => 'submenu'), | |
| 288 '<span>'.rcube::Q($this->gettext('tb_label_contextmenu_title')).'</span>' . $this->_gen_label_submenu($args, 'tb_label_ctxm_submenu')); | |
| 289 $out .= html::tag('ul', array('id' => 'tb_label_ctxm_mainmenu'), $li); | |
| 29 | 290 #rcube::write_log('lab',"stblc $out"); |
| 0 | 291 $this->api->output->add_footer(html::div(array('style' => 'display: none;'), $out)); |
| 292 } | |
| 293 | |
| 294 private function _gen_label_submenu($args, $id) | |
|
26
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
295 # never called? |
| 0 | 296 { |
| 297 $out = ''; | |
| 298 $custom_labels = $this->rc->config->get('tb_label_custom_labels'); | |
|
1
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
299 $max_id = $this->rc->config->get('tb_max_label'); |
|
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
300 for ($i = 0; $i <= $max_id; $i++) |
| 0 | 301 { |
| 302 $separator = ($i == 0)? ' separator_below' :''; | |
| 303 $out .= '<li class="label'.$i.$separator. | |
| 304 ' ctxm_tb_label"><a href="#ctxm_tb_label" class="active" onclick="rcmail_ctxm_label_set('.$i.')"><span>'. | |
| 305 $i.' '.$custom_labels[$i]. | |
| 306 '</span></a></li>'; | |
| 307 } | |
| 308 $out = html::tag('ul', array('class' => 'popupmenu toolbarmenu folders', 'id' => $id), $out); | |
| 309 return $out; | |
| 310 } | |
| 311 | |
| 312 public function read_single_flags($args) | |
| 313 { | |
| 9 | 314 #rcube::write_log($this->name, print_r(($args['object']), true)); |
| 0 | 315 if (!isset($args['object'])) { |
| 316 return; | |
| 317 } | |
| 318 | |
| 319 if (is_array($args['object']->headers->flags)) | |
| 320 { | |
| 321 $this->message_tb_labels = array(); | |
| 322 foreach ($args['object']->headers->flags as $flagname => $flagvalue) | |
| 323 { | |
| 324 $flag = is_numeric("$flagvalue")? $flagname:$flagvalue;// for compatibility with < 0.5.4 | |
| 325 $flag = strtolower($flag); | |
| 326 if (preg_match('/^\$?label/', $flag)) | |
| 327 { | |
| 328 $flag_no = preg_replace('/^\$?label/', '', $flag); | |
| 35 | 329 #rcube::write_log($this->name, "Single message Flag: ".$flag." Flag_no:".$flag_no); |
| 0 | 330 $this->message_tb_labels[] = (int)$flag_no; |
| 331 } | |
| 332 } | |
| 333 } | |
| 334 # -- no return value for this hook | |
| 335 } | |
| 336 | |
| 337 /** | |
| 338 * Writes labelnumbers for single message display | |
| 339 * Coloring of Message header table happens via Javascript | |
| 340 */ | |
| 341 public function color_headers($p) | |
| 342 { | |
| 9 | 343 #rcube::write_log($this->name, print_r($p, true)); |
| 0 | 344 # -- always write array, even when empty |
| 345 $p['content'] .= '<script type="text/javascript"> | |
| 346 var tb_labels_for_message = ['.join(',', $this->message_tb_labels).']; | |
| 347 </script>'; | |
| 348 return $p; | |
| 349 } | |
| 350 | |
| 351 public function read_flags($args) | |
| 352 { | |
| 353 // add color information for all messages | |
| 354 // dont loop over all messages if we dont have any highlights or no msgs | |
| 355 if (!isset($args['messages']) or !is_array($args['messages'])) { | |
| 356 return $args; | |
| 357 } | |
| 358 // loop over all messages and add $LabelX info to the extra_flags | |
|
24
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
359 $mbox = $this->rc->output->get_env('mailbox') ?: $this->rc->storage->get_folder(); |
| 29 | 360 #rcube::write_log($this->name, "mbox: $mbox"); |
| 0 | 361 foreach($args['messages'] as $message) |
| 362 { | |
| 363 $message->list_flags['extra_flags']['tb_labels'] = array(); # always set extra_flags, needed for javascript later! | |
|
24
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
364 $message->list_flags['extra_flags']['tb_lparms'] = array(); |
| 23 | 365 $keyPos = array_search($_SESSION['sort_col'],$this->rc->config->get('tb_label_parm_labels')); |
| 29 | 366 #rcube::write_log($this->name,"sort? $keyPos ".$_SESSION['sort_order']." ".print_r($this->rc->config->get('tb_label_parm_labels'),true)); |
| 21 | 367 if (is_array($message->flags)) |
| 0 | 368 foreach ($message->flags as $flagname => $flagvalue) |
| 369 { | |
| 370 $flag = is_numeric("$flagvalue")? $flagname:$flagvalue;// for compatibility with < 0.5.4 | |
| 371 $flag = strtolower($flag); | |
| 372 if (preg_match('/^\$?label/', $flag)) | |
| 373 { | |
| 374 $flag_no = preg_replace('/^\$?label/', '', $flag); | |
| 29 | 375 #rcube::write_log($this->name, "Flag:".$flag." Flag_no:".$flag_no); |
| 20 | 376 if ($ppos = strpos($flag_no,'_') > -1) { |
| 377 // We have a flag parameter value... | |
| 23 | 378 $pn=(int)substr($flag_no,0,$ppos); |
| 379 $pv=substr($flag_no,$ppos+1); | |
| 20 | 380 $message->list_flags['extra_flags']['tb_lparms'][]=array( |
| 23 | 381 'number' => $pn, |
| 382 'parm' => $pv); | |
|
24
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
383 if ($keyPos && $message->depth==0) { |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
384 $message->sortKey=array_map('intval',preg_split('#[/-]#',$pv)); |
| 23 | 385 } |
| 20 | 386 } |
| 387 else { | |
| 388 $message->list_flags['extra_flags']['tb_labels'][] = (int)$flag_no; | |
| 389 } | |
| 0 | 390 } |
| 391 } | |
| 392 } | |
| 23 | 393 if ($keyPos) { |
| 394 $rev = $_SESSION['sort_order']=='DESC'; | |
|
24
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
395 $datesSort = |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
396 function($a, $b) use ($rev) { |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
397 if ($ak=$a->sortKey) { |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
398 if ($bk=$b->sortKey) { |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
399 // each key is sd sm ed em |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
400 if ($ak[1]<$bk[1]) return $rev?1:-1; |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
401 if ($ak[1]>$bk[1]) return $rev?-1:1; |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
402 // start month is the same |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
403 if ($ak[0]<$bk[0]) return $rev?1:-1; |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
404 if ($ak[0]>$bk[0]) return $rev?-1:1; |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
405 // start date is the same |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
406 if ($ak[3]<$bk[3]) return $rev?1:-1; |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
407 if ($ak[3]>$bk[3]) return $rev?-1:1; |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
408 // end month is the same |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
409 if ($ak[2]<$bk[2]) return $rev?1:-1; |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
410 if ($ak[2]>$bk[2]) return $rev?-1:1; |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
411 // both dates are the same |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
412 return 0; |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
413 } |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
414 else { |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
415 return $rev?1:-1; |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
416 } |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
417 } |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
418 else if ($b->sortKey) { |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
419 return $rev?-1:1; |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
420 } |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
421 else { |
| 23 | 422 return 0; |
| 423 } | |
|
24
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
424 }; |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
425 if ($this->rc->config->get('message_threading')[$mbox]) { |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
426 // The threading information is contained in three fields: |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
427 // depth, parent_uid and uid |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
428 // I _think_ if you gave every depth0 message its dates as key |
| 25 | 429 // every depth>0 [already sorted by date, see list.inc:71] |
|
24
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
430 // Then first sort all the depth0 messages into a new array |
| 25 | 431 // then iterate over them, pull all depth1 with shared parent |
|
24
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
432 // insert after parent |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
433 // repeat at depth 1, etc. |
| 25 | 434 $sm = array(); // sorted result accumulates here |
| 435 $rm = array(); // unprocessed remnant | |
| 436 foreach ($args['messages'] as $m) { | |
| 437 if ($m->depth===0) { | |
| 438 $sm[]=$m; | |
| 439 } | |
| 440 else { | |
| 441 $rm[]=$m; | |
| 442 } | |
| 443 } | |
| 27 | 444 #rcube::write_log($this->name,"ts0: |".$rm[0]->depth."| |".($rm[0]->depth===0)."|"); |
| 25 | 445 usort($sm,$datesSort); |
| 446 $depth=0; | |
| 447 $foundSome=true; | |
| 448 while ($foundSome) { | |
| 27 | 449 #rcube::write_log($this->name,"ts: $depth ".count($sm).' '.count($rm)); |
| 25 | 450 $foundSome=false; |
| 451 $tsm = array(); | |
| 452 $trm = array(); | |
| 453 foreach ($sm as $m) { | |
| 454 $tsm[]=$m; | |
| 455 if ($m->depth===$depth) { | |
| 456 $puid = $m->uid; | |
| 457 foreach ($rm as $c) { | |
| 458 if ($c->parent_uid===$puid) { | |
| 459 $tsm[]=$c; | |
| 460 $foundSome=true; | |
| 461 } | |
| 462 else { | |
| 463 $trm[]=$c; | |
| 464 } | |
| 465 } | |
| 466 $rm = $trm; | |
| 467 $trm = array(); | |
| 468 } | |
| 469 } | |
| 470 $sm = $tsm; | |
| 471 $depth+=1; | |
| 472 } | |
| 473 $args['messages']=$sm; | |
|
24
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
474 } |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
475 else { |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
476 usort($args['messages'],$datesSort); |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
477 } |
| 23 | 478 } |
| 0 | 479 return($args); |
| 480 } | |
| 481 | |
| 482 // set flags in IMAP server | |
| 483 function set_flags() | |
| 484 { | |
| 29 | 485 #rcube::write_log($this->name, "set: ".print_r($_GET, true)); |
| 0 | 486 |
| 487 $imap = $this->rc->imap; | |
| 488 $cbox = rcube_utils::get_input_value('_cur', rcube_utils::INPUT_GET); | |
| 489 $mbox = rcube_utils::get_input_value('_mbox', rcube_utils::INPUT_GET); | |
| 490 $toggle_label = rcube_utils::get_input_value('_toggle_label', rcube_utils::INPUT_GET); | |
| 491 $flag_uids = rcube_utils::get_input_value('_flag_uids', rcube_utils::INPUT_GET); | |
| 492 $flag_uids = explode(',', $flag_uids); | |
| 493 $unflag_uids = rcube_utils::get_input_value('_unflag_uids', rcube_utils::INPUT_GET); | |
| 494 $unflag_uids = explode(',', $unflag_uids); | |
| 495 | |
| 496 $imap->conn->flags = array_merge($imap->conn->flags, $this->add_tb_flags); | |
| 497 | |
| 9 | 498 #rcube::write_log($this->name, print_r($flag_uids, true)); |
| 499 #rcube::write_log($this->name, print_r($unflag_uids, true)); | |
| 0 | 500 |
| 501 if (!is_array($unflag_uids) | |
| 502 || !is_array($flag_uids)) | |
| 503 return false; | |
| 504 | |
| 505 $imap->set_flag($flag_uids, $toggle_label, $mbox); | |
|
24
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
506 // belt and braces |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
507 if (count($unflag_uids)>0) { |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
508 $flaggedMsgs = $imap->list_flags($mbox,$unflag_uids); |
| 27 | 509 #rcube::write_log($this->name,'oldFlags: '.print_r($flaggedMsgs,true)); |
|
24
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
510 $fullFlags=array(); |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
511 foreach ($flaggedMsgs as $uid => $flags) { |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
512 foreach ($flags as $flag => $x) { |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
513 $pos=strpos(strtolower($flag),$toggle_label); |
| 27 | 514 #rcube::write_log($this->name,"flag?: $flag $toggle_label $pos"); |
|
24
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
515 if ($pos>-1 && $pos<2 && !in_array($flag,$fullFlags)) { |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
516 $fullFlags[]=$flag; |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
517 } |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
518 } |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
519 } |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
520 if (count($fullFlags)==0) { |
| 27 | 521 #rcube::write_log('errors',"no full flags for $toggle_label in ".print_r($flaggedMsgs,true)); |
|
24
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
522 $imap->set_flag($unflag_uids, "UN$toggle_label", $mbox); |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
523 } |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
524 else { |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
525 foreach ($fullFlags as $flag) { |
| 27 | 526 #rcube::write_log($this->name,"UNsetting $flag in $mbox for ".join(',',$unflag_uids)); |
|
24
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
527 $imap->set_flag($unflag_uids, "UN$flag", $mbox); |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
528 } |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
529 } |
|
4869fae20b88
do better at flag deletion, unthreaded dates sort working, preparing for threaded
Charlie Root
parents:
23
diff
changeset
|
530 } |
| 0 | 531 $this->api->output->send(); |
| 532 } | |
| 533 | |
|
26
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
534 function tblabelpopup() |
| 0 | 535 { |
| 536 $custom_labels = $this->rc->config->get('tb_label_custom_labels'); | |
|
1
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
537 $max_id = $this->rc->config->get('tb_max_label'); |
|
26
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
538 $out = '<div id="tblabelpopup" class="popupmenu"> |
| 0 | 539 <ul class="toolbarmenu">'; |
|
1
5821049f1791
most of the way to allowing arbitrarily many labels
Charlie Root
parents:
0
diff
changeset
|
540 for ($i = 0; $i <= $max_id; $i++) |
| 0 | 541 { |
| 542 $separator = ($i == 0)? ' separator_below' :''; | |
|
26
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
543 $out .= '<li class="label'.$i.$separator.'"><a href="#" id="tblabel'.$i.'" class="active">'.$i.' '.$custom_labels[$i].'</a></li>'; |
| 0 | 544 } |
| 545 $out .= '</ul> | |
| 546 </div>'; | |
|
26
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
547 $this->rc->output->add_gui_object('tblabelpopup_obj', 'tblabelpopup'); |
| 27 | 548 #rcube::write_log('lab',"tblp $out"); |
|
26
b2b6c0af2383
remove _ from name, lots of other hacks to get label context menu working
Charlie Root
parents:
25
diff
changeset
|
549 $this->rc->output->add_footer($out); |
| 0 | 550 } |
| 31 | 551 |
| 552 public static function whiteMessage($data) { | |
| 553 require_once 'Mail/RFC822.php'; | |
| 35 | 554 $message = $data['message']; |
| 555 $hdrs = $message->headers(); | |
| 31 | 556 $to = $hdrs['To']; |
| 557 $cc = $hdrs['Cc']; | |
| 35 | 558 $util = new Mail_RFC822(); |
| 559 $addrs = $util->parseAddressList($to); | |
| 31 | 560 if ($cc) { |
| 35 | 561 foreach ($util->parseAddressList($cc) as $addr) { |
| 31 | 562 $addrs[]=$addr; |
| 563 } | |
| 564 } | |
| 565 #rcube::write_log('lab',"cc: ".print_r($cca,true)); | |
| 566 $wp = popen("/usr/local/bin/makeWhite.sh >>/var/log/white.log 2>&1",'w'); | |
| 567 foreach ($addrs as $addr) { | |
| 568 fwrite($wp,$addr->mailbox.'@'.$addr->host."\n"); | |
| 569 } | |
| 570 fclose($wp); | |
| 571 return $data; | |
| 572 } | |
| 573 | |
| 0 | 574 } |
| 575 |
