You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1201 lines
37 KiB
JavaScript
1201 lines
37 KiB
JavaScript
/**
|
|
* (Manage)Sieve Filters plugin
|
|
*
|
|
* @licstart The following is the entire license notice for the
|
|
* JavaScript code in this file.
|
|
*
|
|
* Copyright (c) 2012-2014, The Roundcube Dev Team
|
|
*
|
|
* The JavaScript code in this page is free software: you can redistribute it
|
|
* and/or modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation, either version 3 of
|
|
* the License, or (at your option) any later version.
|
|
*
|
|
* @licend The above is the entire license notice
|
|
* for the JavaScript code in this file.
|
|
*/
|
|
|
|
if (window.rcmail) {
|
|
rcmail.addEventListener('init', function(evt) {
|
|
// add managesieve-create command to message_commands array,
|
|
// so it's state will be updated on message selection/unselection
|
|
if (rcmail.env.task == 'mail') {
|
|
if (rcmail.env.action != 'show')
|
|
rcmail.env.message_commands.push('managesieve-create');
|
|
else
|
|
rcmail.enable_command('managesieve-create', true);
|
|
}
|
|
|
|
if (rcmail.env.task == 'mail' || rcmail.env.action.startsWith('plugin.managesieve')) {
|
|
// Create layer for form tips
|
|
if (!rcmail.env.framed) {
|
|
rcmail.env.ms_tip_layer = $('<div id="managesieve-tip" class="popupmenu"></div>');
|
|
rcmail.env.ms_tip_layer.appendTo(document.body);
|
|
}
|
|
}
|
|
|
|
// register commands
|
|
rcmail.register_command('plugin.managesieve-save', function() { rcmail.managesieve_save() });
|
|
rcmail.register_command('plugin.managesieve-act', function() { rcmail.managesieve_act() });
|
|
rcmail.register_command('plugin.managesieve-add', function() { rcmail.managesieve_add() });
|
|
rcmail.register_command('plugin.managesieve-del', function() { rcmail.managesieve_del() });
|
|
rcmail.register_command('plugin.managesieve-move', function() { rcmail.managesieve_move() });
|
|
rcmail.register_command('plugin.managesieve-setadd', function() { rcmail.managesieve_setadd() });
|
|
rcmail.register_command('plugin.managesieve-setdel', function() { rcmail.managesieve_setdel() });
|
|
rcmail.register_command('plugin.managesieve-setact', function() { rcmail.managesieve_setact() });
|
|
rcmail.register_command('plugin.managesieve-setget', function() { rcmail.managesieve_setget() });
|
|
rcmail.register_command('plugin.managesieve-seteditraw', function() { rcmail.managesieve_seteditraw() });
|
|
|
|
if (rcmail.env.action.startsWith('plugin.managesieve')) {
|
|
if (rcmail.gui_objects.sieveform) {
|
|
rcmail.enable_command('plugin.managesieve-save', true);
|
|
sieve_form_init();
|
|
}
|
|
else if (rcmail.gui_objects.sievesetrawform) {
|
|
rcmail.enable_command('plugin.managesieve-save', true);
|
|
sieve_raw_editor_init();
|
|
}
|
|
else {
|
|
rcmail.enable_command('plugin.managesieve-add', !rcmail.env.sieveconnerror && $.inArray('new_rule', rcmail.env.managesieve_disabled_actions) == -1);
|
|
rcmail.enable_command('plugin.managesieve-setadd', !rcmail.env.sieveconnerror && $.inArray('new_set', rcmail.env.managesieve_disabled_actions) == -1);
|
|
}
|
|
|
|
var setcnt, set = rcmail.env.currentset;
|
|
|
|
if (rcmail.gui_objects.filterslist) {
|
|
rcmail.filters_list = new rcube_list_widget(rcmail.gui_objects.filterslist,
|
|
{multiselect:false, draggable:true, keyboard:true});
|
|
|
|
rcmail.filters_list
|
|
.addEventListener('select', function(e) { rcmail.managesieve_select(e); })
|
|
.addEventListener('dragstart', function(e) { rcmail.managesieve_dragstart(e); })
|
|
.addEventListener('dragend', function(e) { rcmail.managesieve_dragend(e); })
|
|
.addEventListener('initrow', function(row) {
|
|
row.obj.onmouseover = function() { rcmail.managesieve_focus_filter(row); };
|
|
row.obj.onmouseout = function() { rcmail.managesieve_unfocus_filter(row); };
|
|
})
|
|
.init();
|
|
}
|
|
|
|
if (rcmail.gui_objects.filtersetslist) {
|
|
rcmail.filtersets_list = new rcube_list_widget(rcmail.gui_objects.filtersetslist,
|
|
{multiselect:false, draggable:false, keyboard:true});
|
|
|
|
rcmail.filtersets_list.init().focus();
|
|
|
|
if (set != null) {
|
|
$('#filterset-name').text(set);
|
|
set = rcmail.managesieve_setid(set);
|
|
rcmail.filtersets_list.select(set);
|
|
}
|
|
|
|
// attach select event after initial record was selected
|
|
rcmail.filtersets_list.addEventListener('select', function(e) { rcmail.managesieve_setselect(e); });
|
|
|
|
setcnt = rcmail.filtersets_list.rowcount;
|
|
rcmail.enable_command('plugin.managesieve-set', true);
|
|
rcmail.enable_command('plugin.managesieve-setact', setcnt > 0 && $.inArray('enable_disable_set', rcmail.env.managesieve_disabled_actions) == -1);
|
|
rcmail.enable_command('plugin.managesieve-setget', setcnt > 0 && $.inArray('download_set', rcmail.env.managesieve_disabled_actions) == -1);
|
|
rcmail.enable_command('plugin.managesieve-setdel', setcnt > 1 && $.inArray('delete_set', rcmail.env.managesieve_disabled_actions) == -1);
|
|
rcmail.enable_command('plugin.managesieve-seteditraw', setcnt > 0 && rcmail.env.raw_sieve_editor);
|
|
|
|
// Fix dragging filters over sets list
|
|
$('tr', rcmail.gui_objects.filtersetslist).each(function (i, e) { rcmail.managesieve_fixdragend(e); });
|
|
}
|
|
}
|
|
|
|
if (rcmail.gui_objects.sieveform && rcmail.env.rule_disabled)
|
|
$('#disabled').attr('checked', true);
|
|
});
|
|
};
|
|
|
|
/*********************************************************/
|
|
/********* Managesieve UI methods *********/
|
|
/*********************************************************/
|
|
|
|
rcube_webmail.prototype.managesieve_add = function()
|
|
{
|
|
this.load_managesieveframe('_nav=hide', true);
|
|
};
|
|
|
|
rcube_webmail.prototype.managesieve_del = function()
|
|
{
|
|
var id = this.filters_list.get_single_selection();
|
|
this.confirm_dialog(this.get_label('managesieve.filterdeleteconfirm'), 'delete', function(e, ref) {
|
|
var post = '_act=delete&_fid=' + ref.filters_list.rows[id].uid,
|
|
lock = ref.set_busy(true, 'loading');
|
|
|
|
ref.http_post('plugin.managesieve-action', post, lock);
|
|
});
|
|
};
|
|
|
|
rcube_webmail.prototype.managesieve_act = function()
|
|
{
|
|
var id = this.filters_list.get_single_selection(),
|
|
lock = this.set_busy(true, 'loading');
|
|
|
|
this.http_post('plugin.managesieve-action',
|
|
'_act=act&_fid='+this.filters_list.rows[id].uid, lock);
|
|
};
|
|
|
|
// Filter selection
|
|
rcube_webmail.prototype.managesieve_select = function(list)
|
|
{
|
|
var id = list.get_single_selection();
|
|
|
|
if (id != null) {
|
|
id = list.rows[id].uid;
|
|
this.load_managesieveframe('_fid=' + id);
|
|
}
|
|
|
|
var has_id = typeof(id) != 'undefined' && id != null;
|
|
|
|
this.enable_command('plugin.managesieve-act', has_id);
|
|
this.enable_command('plugin.managesieve-del', has_id && $.inArray('delete_rule', rcmail.env.managesieve_disabled_actions) == -1);
|
|
};
|
|
|
|
// Set selection
|
|
rcube_webmail.prototype.managesieve_setselect = function(list)
|
|
{
|
|
this.enable_command('plugin.managesieve-setdel', list.rowcount > 1 && $.inArray('delete_set', rcmail.env.managesieve_disabled_actions) == -1);
|
|
this.enable_command('plugin.managesieve-setact', list.rowcount > 0 && $.inArray('enable_disable_set', rcmail.env.managesieve_disabled_actions) == -1);
|
|
this.enable_command('plugin.managesieve-setget', list.rowcount > 0 && $.inArray('delete_set', rcmail.env.managesieve_disabled_actions) == -1);
|
|
this.enable_command('plugin.managesieve-seteditraw', list.rowcount > 0 && this.env.raw_sieve_editor);
|
|
|
|
if (rcmail.env.contextmenu_opening)
|
|
return;
|
|
|
|
this.show_contentframe(false);
|
|
this.filters_list.clear(true);
|
|
|
|
var id = list.get_single_selection();
|
|
if (id != null) {
|
|
this.managesieve_list(this.env.filtersets[id]);
|
|
$('#filterset-name').text(this.env.filtersets[id]);
|
|
}
|
|
};
|
|
|
|
rcube_webmail.prototype.managesieve_rowid = function(id)
|
|
{
|
|
var i, rows = this.filters_list.rows;
|
|
|
|
for (i in rows)
|
|
if (rows[i] != null && rows[i].uid == id)
|
|
return i;
|
|
};
|
|
|
|
// Returns set's identifier
|
|
rcube_webmail.prototype.managesieve_setid = function(name)
|
|
{
|
|
for (var i in this.env.filtersets)
|
|
if (this.env.filtersets[i] == name)
|
|
return i;
|
|
};
|
|
|
|
// Filters listing request
|
|
rcube_webmail.prototype.managesieve_list = function(script)
|
|
{
|
|
var lock = this.set_busy(true, 'loading');
|
|
|
|
this.http_post('plugin.managesieve-action', '_act=list&_set='+urlencode(script), lock);
|
|
};
|
|
|
|
// Script download request
|
|
rcube_webmail.prototype.managesieve_setget = function()
|
|
{
|
|
var id = this.filtersets_list.get_single_selection(),
|
|
script = this.env.filtersets[id];
|
|
|
|
this.goto_url('plugin.managesieve-action', {_act: 'setget', _set: script}, false, true);
|
|
};
|
|
|
|
// Set activate/deactivate request
|
|
rcube_webmail.prototype.managesieve_setact = function()
|
|
{
|
|
var id = this.filtersets_list.get_single_selection(),
|
|
lock = this.set_busy(true, 'loading'),
|
|
script = this.env.filtersets[id],
|
|
action = $('#rcmrow'+id).hasClass('disabled') ? 'setact' : 'deact';
|
|
|
|
this.http_post('plugin.managesieve-action', '_act='+action+'&_set='+urlencode(script), lock);
|
|
};
|
|
|
|
// Set delete request
|
|
rcube_webmail.prototype.managesieve_setdel = function()
|
|
{
|
|
var id = this.filtersets_list.get_single_selection();
|
|
this.confirm_dialog(this.get_label('managesieve.setdeleteconfirm'), 'delete', function(e, ref) {
|
|
var script = ref.env.filtersets[id],
|
|
lock = ref.set_busy(true, 'loading');
|
|
|
|
ref.http_post('plugin.managesieve-action', '_act=setdel&_set=' + urlencode(script), lock);
|
|
});
|
|
};
|
|
|
|
// Set edit raw request
|
|
rcube_webmail.prototype.managesieve_seteditraw = function()
|
|
{
|
|
var id = this.filtersets_list.get_single_selection(),
|
|
script = this.env.filtersets[id];
|
|
|
|
this.load_managesieveframe('_nav=hide&_seteditraw=1&_set=' + urlencode(script), true);
|
|
};
|
|
|
|
// Set add request
|
|
rcube_webmail.prototype.managesieve_setadd = function()
|
|
{
|
|
this.load_managesieveframe('_nav=hide&_newset=1', true);
|
|
};
|
|
|
|
rcube_webmail.prototype.managesieve_updatelist = function(action, o)
|
|
{
|
|
this.set_busy(true);
|
|
|
|
switch (action) {
|
|
// Delete filter row
|
|
case 'del':
|
|
var id = o.id, list = this.filters_list;
|
|
|
|
list.remove_row(this.managesieve_rowid(o.id));
|
|
this.show_contentframe(false);
|
|
this.reset_filters_list();
|
|
|
|
// filter identifiers changed, fix the list
|
|
$('tr', this.filters_list.list).each(function() {
|
|
// remove hidden (deleted) rows
|
|
if (this.style.display == 'none') {
|
|
$(this).detach();
|
|
return;
|
|
}
|
|
|
|
var rowid = this.id.substr(6);
|
|
|
|
// remove all attached events
|
|
$(this).off();
|
|
|
|
// update row id
|
|
if (rowid > id) {
|
|
this.uid = rowid - 1;
|
|
$(this).attr('id', 'rcmrow' + this.uid);
|
|
}
|
|
});
|
|
list.init();
|
|
|
|
break;
|
|
|
|
// Update filter row
|
|
case 'update':
|
|
var i, row = $('#rcmrow'+this.managesieve_rowid(o.id));
|
|
|
|
if (o.name)
|
|
$('td', row).text(o.name);
|
|
if (o.disabled)
|
|
row.addClass('disabled');
|
|
else
|
|
row.removeClass('disabled');
|
|
|
|
$('#disabled', $('iframe').contents()).prop('checked', o.disabled);
|
|
|
|
break;
|
|
|
|
// Add filter row to the list
|
|
case 'add':
|
|
var list = this.filters_list,
|
|
row = $('<tr><td class="name"></td></tr>');
|
|
|
|
$('td', row).text(o.name);
|
|
row.attr('id', 'rcmrow'+o.id);
|
|
if (o.disabled)
|
|
row.addClass('disabled');
|
|
|
|
list.insert_row(row.get(0));
|
|
list.highlight_row(o.id);
|
|
|
|
this.enable_command('plugin.managesieve-del', $.inArray('delete_rule', rcmail.env.managesieve_disabled_actions) == -1);
|
|
this.enable_command('plugin.managesieve-act', true);
|
|
|
|
break;
|
|
|
|
// Filling rules list
|
|
case 'list':
|
|
var i, tr, td, el, list = this.filters_list;
|
|
|
|
if (o.clear)
|
|
list.clear();
|
|
|
|
for (i in o.list) {
|
|
el = o.list[i];
|
|
tr = document.createElement('TR');
|
|
td = document.createElement('TD');
|
|
|
|
$(td).text(el.name);
|
|
td.className = 'name';
|
|
tr.id = 'rcmrow' + el.id;
|
|
if (el['class'])
|
|
tr.className = el['class'];
|
|
tr.appendChild(td);
|
|
|
|
list.insert_row(tr);
|
|
}
|
|
|
|
if (o.set)
|
|
list.highlight_row(o.set);
|
|
else
|
|
this.enable_command('plugin.managesieve-del', 'plugin.managesieve-act', false);
|
|
|
|
break;
|
|
|
|
// Sactivate/deactivate set
|
|
case 'setact':
|
|
var id = this.managesieve_setid(o.name), row = $('#rcmrow' + id);
|
|
if (o.active) {
|
|
if (o.all)
|
|
$('tr', this.gui_objects.filtersetslist).addClass('disabled');
|
|
row.removeClass('disabled');
|
|
}
|
|
else
|
|
row.addClass('disabled');
|
|
|
|
break;
|
|
|
|
// Delete set row
|
|
case 'setdel':
|
|
var id = this.managesieve_setid(o.name);
|
|
|
|
this.filters_list.clear();
|
|
this.show_contentframe(false);
|
|
this.enable_command('plugin.managesieve-setdel', 'plugin.managesieve-setact',
|
|
'plugin.managesieve-setget', 'plugin.managesieve-seteditraw', false);
|
|
|
|
this.filtersets_list.remove_row(id, true);
|
|
delete this.env.filtersets[id];
|
|
break;
|
|
|
|
// Create set row
|
|
case 'setadd':
|
|
var id = 'S' + new Date().getTime(),
|
|
list = this.filtersets_list,
|
|
row = $('<tr class="disabled"><td class="name"></td></tr>');
|
|
|
|
$('td', row).text(o.name);
|
|
row.attr('id', 'rcmrow'+id);
|
|
|
|
this.env.filtersets[id] = o.name;
|
|
list.insert_row(row.get(0));
|
|
|
|
// move row into its position on the list
|
|
if (o.index != list.rowcount-1) {
|
|
row.detach();
|
|
var elem = $('tr:visible', list.list).get(o.index);
|
|
row.insertBefore(elem);
|
|
}
|
|
|
|
list.select(id);
|
|
|
|
// Fix dragging filters over sets list
|
|
this.managesieve_fixdragend(row);
|
|
|
|
break;
|
|
|
|
case 'refresh':
|
|
this.reset_filters_list(true);
|
|
break;
|
|
}
|
|
|
|
this.set_busy(false);
|
|
};
|
|
|
|
// Resets filters list state
|
|
rcube_webmail.prototype.reset_filters_list = function(reload)
|
|
{
|
|
this.filters_list.clear_selection();
|
|
this.enable_command('plugin.managesieve-act', 'plugin.managesieve-del', false);
|
|
|
|
if (reload) {
|
|
var id = this.filtersets_list.get_single_selection();
|
|
|
|
this.filters_list.clear(true);
|
|
this.managesieve_list(this.env.filtersets[id]);
|
|
}
|
|
};
|
|
|
|
// load filter frame
|
|
rcube_webmail.prototype.load_managesieveframe = function(add_url, reset)
|
|
{
|
|
if (reset)
|
|
this.reset_filters_list();
|
|
|
|
if (this.env.contentframe && window.frames && window.frames[this.env.contentframe]) {
|
|
var lock = this.set_busy(true, 'loading'),
|
|
target = window.frames[this.env.contentframe];
|
|
|
|
target.location.href = this.env.comm_path
|
|
+ '&_action=plugin.managesieve-action&_framed=1&_unlock=' + lock
|
|
+ (add_url ? ('&' + add_url) : '');
|
|
}
|
|
};
|
|
|
|
// load filter frame
|
|
rcube_webmail.prototype.managesieve_dragstart = function(list)
|
|
{
|
|
var id = this.filters_list.get_single_selection();
|
|
|
|
this.drag_active = true;
|
|
this.drag_filter = id;
|
|
};
|
|
|
|
rcube_webmail.prototype.managesieve_dragend = function(e)
|
|
{
|
|
if (this.drag_active) {
|
|
if (this.drag_filter_target) {
|
|
var lock = this.set_busy(true, 'loading');
|
|
|
|
this.show_contentframe(false);
|
|
this.http_post('plugin.managesieve-action', '_act=move&_fid='+this.drag_filter
|
|
+'&_to='+this.drag_filter_target, lock);
|
|
}
|
|
this.drag_active = false;
|
|
}
|
|
};
|
|
|
|
// Fixes filters dragging over sets list
|
|
// @TODO: to be removed after implementing copying filters
|
|
rcube_webmail.prototype.managesieve_fixdragend = function(elem)
|
|
{
|
|
var p = this;
|
|
$(elem).on('mouseup' + ((bw.iphone || bw.ipad) ? ' touchend' : ''), function(e) {
|
|
if (p.drag_active)
|
|
p.filters_list.drag_mouse_up(e);
|
|
});
|
|
};
|
|
|
|
rcube_webmail.prototype.managesieve_focus_filter = function(row)
|
|
{
|
|
var id = row.id.replace(/^rcmrow/, '');
|
|
if (this.drag_active && id != this.drag_filter) {
|
|
this.drag_filter_target = id;
|
|
$(row.obj).addClass(id < this.drag_filter ? 'filtermoveup' : 'filtermovedown');
|
|
}
|
|
};
|
|
|
|
rcube_webmail.prototype.managesieve_unfocus_filter = function(row)
|
|
{
|
|
if (this.drag_active) {
|
|
$(row.obj).removeClass('filtermoveup filtermovedown');
|
|
this.drag_filter_target = null;
|
|
}
|
|
};
|
|
|
|
/*********************************************************/
|
|
/********* Filter Form methods *********/
|
|
/*********************************************************/
|
|
|
|
// Form submition
|
|
rcube_webmail.prototype.managesieve_save = function()
|
|
{
|
|
if (this.env.action == 'plugin.managesieve-vacation') {
|
|
var data = $(this.gui_objects.sieveform).serialize();
|
|
this.http_post('plugin.managesieve-vacation', data, this.display_message(this.get_label('managesieve.vacation.saving'), 'loading'));
|
|
return;
|
|
}
|
|
|
|
if (this.env.action == 'plugin.managesieve-forward') {
|
|
var data = $(this.gui_objects.sieveform).serialize();
|
|
this.http_post('plugin.managesieve-forward', data, this.display_message(this.get_label('managesieve.forward.saving'), 'loading'));
|
|
return;
|
|
}
|
|
|
|
if (this.gui_objects.sieveform) {
|
|
if (parent.rcmail && parent.rcmail.filters_list && this.gui_objects.sieveform.name != 'filtersetform') {
|
|
var id = parent.rcmail.filters_list.get_single_selection();
|
|
if (id != null)
|
|
this.gui_objects.sieveform.elements['_fid'].value = parent.rcmail.filters_list.rows[id].uid;
|
|
}
|
|
this.gui_objects.sieveform.submit();
|
|
}
|
|
else if (this.gui_objects.sievesetrawform) {
|
|
this.gui_objects.sievesetrawform.submit();
|
|
}
|
|
};
|
|
|
|
// Operations on filters form
|
|
rcube_webmail.prototype.managesieve_ruleadd = function(id)
|
|
{
|
|
this.http_post('plugin.managesieve-action', '_act=ruleadd&_rid='+id);
|
|
};
|
|
|
|
rcube_webmail.prototype.managesieve_rulefill = function(content, id, after)
|
|
{
|
|
if (content != '') {
|
|
// create new element
|
|
var div = $('#rules')[0],
|
|
row = $('<div>').attr({'class': 'rulerow', id: 'rulerow'+id})
|
|
.html(content);
|
|
|
|
this.managesieve_insertrow(div, row, after);
|
|
|
|
// initialize smart list inputs
|
|
$('textarea[data-type="list"]', row).each(function() {
|
|
smart_field_init(this);
|
|
});
|
|
|
|
this.managesieve_formbuttons(div);
|
|
}
|
|
};
|
|
|
|
rcube_webmail.prototype.managesieve_ruledel = function(id)
|
|
{
|
|
if ($('#ruledel'+id).hasClass('disabled'))
|
|
return;
|
|
|
|
this.confirm_dialog(this.get_label('managesieve.ruledeleteconfirm'), 'delete', function(e, ref) {
|
|
var row = document.getElementById('rulerow'+id);
|
|
row.parentNode.removeChild(row);
|
|
ref.managesieve_formbuttons(document.getElementById('rules'));
|
|
});
|
|
};
|
|
|
|
rcube_webmail.prototype.managesieve_actionadd = function(id)
|
|
{
|
|
this.http_post('plugin.managesieve-action', '_act=actionadd&_aid='+id);
|
|
};
|
|
|
|
rcube_webmail.prototype.managesieve_actionfill = function(content, id, after)
|
|
{
|
|
if (content != '') {
|
|
var div = $('#actions')[0],
|
|
row = $('<div>').attr({'class': 'actionrow', id: 'actionrow'+id})
|
|
.html(content);
|
|
|
|
this.managesieve_insertrow(div, row, after);
|
|
|
|
// initialize smart list inputs
|
|
$('textarea[data-type="list"]', row).each(function() {
|
|
smart_field_init(this);
|
|
});
|
|
|
|
this.managesieve_formbuttons(div);
|
|
}
|
|
};
|
|
|
|
rcube_webmail.prototype.managesieve_actiondel = function(id)
|
|
{
|
|
if ($('#actiondel'+id).hasClass('disabled'))
|
|
return;
|
|
|
|
this.confirm_dialog(this.get_label('managesieve.actiondeleteconfirm'), 'delete', function(e, ref) {
|
|
var row = document.getElementById('actionrow'+id);
|
|
row.parentNode.removeChild(row);
|
|
ref.managesieve_formbuttons(document.getElementById('actions'));
|
|
});
|
|
};
|
|
|
|
// insert rule/action row in specified place on the list
|
|
rcube_webmail.prototype.managesieve_insertrow = function(div, row, after)
|
|
{
|
|
var node = $('#' + ($(div).attr('id') == 'rules' ? 'rulerow' : 'actionrow') + after)[0];
|
|
|
|
if (node)
|
|
$(row).insertAfter(node);
|
|
else
|
|
$(div).append(row);
|
|
|
|
this.triggerEvent('managesieve.insertrow', {obj: row});
|
|
};
|
|
|
|
// update Delete buttons status
|
|
rcube_webmail.prototype.managesieve_formbuttons = function(div)
|
|
{
|
|
var buttons = $('a.delete', div);
|
|
|
|
buttons.removeClass('disabled');
|
|
if (buttons.length == 1)
|
|
buttons.addClass('disabled');
|
|
};
|
|
|
|
// update vacation addresses field with user identities
|
|
rcube_webmail.prototype.managesieve_vacation_addresses = function(id)
|
|
{
|
|
var lock = this.set_busy(true, 'loading');
|
|
this.http_post('plugin.managesieve-action', {_act: 'addresses', _aid: id}, lock);
|
|
};
|
|
|
|
// update vacation addresses field with user identities
|
|
rcube_webmail.prototype.managesieve_vacation_addresses_update = function(id, addresses)
|
|
{
|
|
var field = $('#vacation_addresses,#action_addresses' + (id || ''));
|
|
smart_field_reset(field.get(0), addresses);
|
|
};
|
|
|
|
function rule_header_select(id)
|
|
{
|
|
var is_header,
|
|
obj = document.getElementById('header' + id),
|
|
size = document.getElementById('rule_size' + id),
|
|
msg = document.getElementById('rule_message' + id),
|
|
op = document.getElementById('rule_op' + id),
|
|
header = document.getElementById('custom_header' + id + '_list'),
|
|
custstr = document.getElementById('custom_var' + id + '_list'),
|
|
mod = document.getElementById('rule_mod' + id),
|
|
trans = document.getElementById('rule_trans' + id),
|
|
comp = document.getElementById('rule_comp' + id),
|
|
mime = document.getElementById('rule_mime' + id),
|
|
mime_part = document.getElementById('rule_mime_part' + id),
|
|
datepart = document.getElementById('rule_date_part' + id),
|
|
dateheader = document.getElementById('rule_date_header_div' + id),
|
|
rule = $('#rule_op' + id),
|
|
h = obj.value,
|
|
set = [op, header, custstr, mod, trans, comp, size, mime, mime_part];
|
|
|
|
if (h == 'size') {
|
|
if (msg) set.push(msg);
|
|
$.each(set, function() { if (this != window) this.style.display = 'none'; });
|
|
size.style.display = '';
|
|
}
|
|
else if (h == 'message' && msg) {
|
|
$.each(set, function() { if (this != window) this.style.display = 'none'; });
|
|
msg.style.display = '';
|
|
}
|
|
else {
|
|
is_header = h != 'body' && h != 'currentdate' && h != 'date' && h != 'string';
|
|
header.style.display = h != '...' ? 'none' : '';
|
|
custstr.style.display = h != 'string' ? 'none' : '';
|
|
size.style.display = 'none';
|
|
op.style.display = '';
|
|
comp.style.display = '';
|
|
mod.style.display = is_header ? '' : 'none';
|
|
trans.style.display = h == 'body' ? '' : 'none';
|
|
if (mime)
|
|
mime.style.display = is_header ? '' : 'none';
|
|
if (mime_part)
|
|
mime_part.style.display = is_header ? '' : 'none';
|
|
if (msg)
|
|
msg.style.display = h == 'message' ? '' : 'none';
|
|
}
|
|
|
|
if (datepart)
|
|
datepart.style.display = h == 'currentdate' || h == 'date' ? 'inline' : 'none';
|
|
if (dateheader)
|
|
dateheader.style.display = h == 'date' ? '' : 'none';
|
|
|
|
$('[value="exists"],[value="notexists"]', rule).prop('disabled', h == 'string');
|
|
if (!rule.val())
|
|
rule.val('contains');
|
|
|
|
rule_op_select(op, id, h);
|
|
rule_mod_select(id, h);
|
|
rule_mime_select(id);
|
|
|
|
obj.style.width = h == '...' ? '40px' : '';
|
|
};
|
|
|
|
function rule_op_select(obj, id, header)
|
|
{
|
|
var target = document.getElementById('rule_target' + id + '_list');
|
|
|
|
if (!header)
|
|
header = document.getElementById('header' + id).value;
|
|
|
|
target.style.display = obj.value.match(/^(exists|notexists)$/) || header.match(/^(size|message)$/) ? 'none' : '';
|
|
};
|
|
|
|
function rule_trans_select(id)
|
|
{
|
|
var obj = document.getElementById('rule_trans_op' + id),
|
|
target = document.getElementById('rule_trans_type' + id);
|
|
|
|
target.style.display = obj.value != 'content' ? 'none' : 'inline';
|
|
};
|
|
|
|
function rule_mod_select(id, header)
|
|
{
|
|
var obj = document.getElementById('rule_mod_op' + id),
|
|
target = document.getElementById('rule_mod_type' + id),
|
|
duplicate = document.getElementById('rule_duplicate_div' + id),
|
|
index = document.getElementById('rule_index_div' + id);
|
|
|
|
if (!header)
|
|
header = document.getElementById('header' + id).value;
|
|
|
|
target.style.display = obj.value != 'address' && obj.value != 'envelope' ? 'none' : '';
|
|
|
|
if (index)
|
|
index.style.display = !header.match(/^(body|currentdate|size|message|string)$/) && obj.value != 'envelope' ? '' : 'none';
|
|
|
|
if (duplicate)
|
|
duplicate.style.display = header == 'message' ? '' : 'none';
|
|
};
|
|
|
|
function rule_join_radio(value)
|
|
{
|
|
$('#rules').css('display', value == 'any' ? 'none' : 'block');
|
|
};
|
|
|
|
function rule_adv_switch(id, elem)
|
|
{
|
|
var elem = $(elem), enabled = elem.hasClass('hide'), adv = $('#rule_advanced'+id);
|
|
|
|
if (enabled) {
|
|
adv.get(0).style.display = 'none';
|
|
elem.removeClass('hide').addClass('show');
|
|
}
|
|
else {
|
|
adv.get(0).style.display = '';
|
|
elem.removeClass('show').addClass('hide');
|
|
}
|
|
};
|
|
|
|
function rule_mime_select(id)
|
|
{
|
|
var elem = $('#rule_mime_type' + id),
|
|
param_elem = $('#rule_mime_param' + id + '_list');
|
|
|
|
if (param_elem.length)
|
|
param_elem[0].style.display = elem.val() == 'param' ? '' : 'none';
|
|
};
|
|
|
|
function action_type_select(id)
|
|
{
|
|
var obj = document.getElementById('action_type' + id),
|
|
v = obj.value, enabled = {},
|
|
elems = {
|
|
mailbox: document.getElementById('action_mailbox' + id),
|
|
target: document.getElementById('redirect_target' + id),
|
|
target_area: document.getElementById('action_target_area' + id),
|
|
flags: document.getElementById('action_flags' + id),
|
|
vacation: document.getElementById('action_vacation' + id),
|
|
forward: document.getElementById('action_forward' + id),
|
|
set: document.getElementById('action_set' + id),
|
|
notify: document.getElementById('action_notify' + id),
|
|
addheader: document.getElementById('action_addheader' + id),
|
|
deleteheader: document.getElementById('action_deleteheader' + id)
|
|
};
|
|
|
|
if (v == 'fileinto' || v == 'fileinto_copy') {
|
|
enabled.mailbox = 1;
|
|
}
|
|
else if (v == 'redirect' || v == 'redirect_copy') {
|
|
enabled.target = 1;
|
|
}
|
|
else if (v.match(/^reject|ereject$/)) {
|
|
enabled.target_area = 1;
|
|
}
|
|
else if (v.match(/^(add|set|remove)flag$/)) {
|
|
enabled.flags = 1;
|
|
}
|
|
else if (v.match(/^(vacation|forward|set|notify|addheader|deleteheader)$/)) {
|
|
enabled[v] = 1;
|
|
}
|
|
|
|
for (var x in elems) {
|
|
if (elems[x])
|
|
elems[x].style.display = !enabled[x] ? 'none' : 'inline';
|
|
}
|
|
};
|
|
|
|
function vacation_action_select()
|
|
{
|
|
var selected = $('#vacation_action').val();
|
|
|
|
$('#action_target_span')[selected == 'discard' || selected == 'keep' ? 'hide' : 'show']();
|
|
};
|
|
|
|
// Inititalizes smart list input
|
|
function smart_field_init(field)
|
|
{
|
|
if (window.UI && UI.smart_field_init)
|
|
return UI.smart_field_init(field);
|
|
|
|
var id = field.id + '_list',
|
|
area = $('<span class="listarea"></span>'),
|
|
list = field.value ? field.value.split("\n") : [''];
|
|
|
|
if ($('#'+id).length)
|
|
return;
|
|
|
|
// add input rows
|
|
$.each(list, function(i, v) {
|
|
area.append(smart_field_row(v, field.name, i, $(field).data('size')));
|
|
});
|
|
|
|
area.attr('id', id);
|
|
field = $(field);
|
|
|
|
if (field.attr('disabled'))
|
|
area.hide();
|
|
// disable the original field anyway, we don't want it in POST
|
|
else
|
|
field.prop('disabled', true);
|
|
|
|
if (field.data('hidden'))
|
|
area.hide();
|
|
|
|
field.after(area);
|
|
|
|
if (field.hasClass('error')) {
|
|
area.addClass('error');
|
|
rcmail.managesieve_tip_register([[id, field.data('tip-class'), field.data('tip-msg')]]);
|
|
}
|
|
};
|
|
|
|
function smart_field_row(value, name, idx, size)
|
|
{
|
|
// build row element content
|
|
var input, content = '<span class="listelement">'
|
|
+ '<span class="reset"></span><input type="text"></span>',
|
|
elem = $(content),
|
|
attrs = {value: value, name: name + '[]'};
|
|
|
|
if (size)
|
|
attrs.size = size;
|
|
|
|
input = $('input', elem).attr(attrs).keydown(function(e) {
|
|
var input = $(this);
|
|
|
|
// element creation event (on Enter)
|
|
if (e.which == 13) {
|
|
var name = input.attr('name').replace(/\[\]$/, ''),
|
|
dt = (new Date()).getTime(),
|
|
elem = smart_field_row('', name, dt, size);
|
|
|
|
input.parent().after(elem);
|
|
$('input', elem).focus();
|
|
}
|
|
// backspace or delete: remove input, focus previous one
|
|
else if ((e.which == 8 || e.which == 46) && input.val() == '') {
|
|
|
|
var parent = input.parent(), siblings = parent.parent().children();
|
|
|
|
if (siblings.length > 1) {
|
|
if (parent.prev().length)
|
|
parent.prev().children('input').focus();
|
|
else
|
|
parent.next().children('input').focus();
|
|
|
|
parent.remove();
|
|
return false;
|
|
}
|
|
}
|
|
});
|
|
|
|
// element deletion event
|
|
$('span[class="reset"]', elem).click(function() {
|
|
var span = $(this.parentNode);
|
|
|
|
if (span.parent().children().length > 1)
|
|
span.remove();
|
|
else
|
|
$('input', span).val('').focus();
|
|
});
|
|
|
|
return elem;
|
|
}
|
|
|
|
// Reset and fill the smart list input with new data
|
|
function smart_field_reset(field, data)
|
|
{
|
|
if (window.UI && UI.smart_field_reset)
|
|
return UI.smart_field_reset(field, data);
|
|
|
|
var id = field.id + '_list',
|
|
list = data.length ? data : [''];
|
|
area = $('#' + id);
|
|
|
|
area.empty();
|
|
|
|
// add input rows
|
|
$.each(list, function(i, v) {
|
|
area.append(smart_field_row(v, field.name, i, $(field).data('size')));
|
|
});
|
|
}
|
|
|
|
// Register onmouse(leave/enter) events for tips on specified form element
|
|
rcube_webmail.prototype.managesieve_tip_register = function(tips)
|
|
{
|
|
if (window.UI && UI.form_errors)
|
|
return UI.form_errors(tips);
|
|
|
|
var n, framed = parent.rcmail,
|
|
tip = framed ? parent.rcmail.env.ms_tip_layer : rcmail.env.ms_tip_layer;
|
|
|
|
for (n in tips) {
|
|
$('#'+tips[n][0])
|
|
.data('tip-class', tips[n][1])
|
|
.data('tip-msg', tips[n][2])
|
|
.mouseleave(function(e) { tip.hide(); })
|
|
.mouseenter(function(e) {
|
|
var elem = $(this),
|
|
offset = elem.offset(),
|
|
left = offset.left,
|
|
top = offset.top - 12,
|
|
minwidth = elem.width(),
|
|
span = $('<span>').addClass(elem.data('tip-class')).text(elem.data('tip-msg'));
|
|
|
|
if (framed) {
|
|
offset = $((rcmail.env.task == 'mail' ? '#sievefilterform > iframe' : '#filter-box'), parent.document).offset();
|
|
top += offset.top;
|
|
left += offset.left;
|
|
}
|
|
|
|
tip.html('').append(span);
|
|
top -= tip.height();
|
|
|
|
tip.css({left: left, top: top, minWidth: (minwidth-2) + 'px'}).show();
|
|
});
|
|
}
|
|
};
|
|
|
|
// format time string
|
|
function sieve_formattime(hour, minutes)
|
|
{
|
|
var i, c, h, time = '', format = rcmail.env.time_format || 'H:i';
|
|
|
|
for (i=0; i<format.length; i++) {
|
|
c = format.charAt(i);
|
|
switch (c) {
|
|
case 'a': time += hour >= 12 ? 'pm' : 'am'; break;
|
|
case 'A': time += hour >= 12 ? 'PM' : 'AM'; break;
|
|
case 'g':
|
|
case 'h':
|
|
h = hour == 0 ? 12 : hour > 12 ? hour - 12 : hour;
|
|
time += (c == 'h' && hour < 10 ? '0' : '') + hour;
|
|
break;
|
|
case 'G': time += hour; break;
|
|
case 'H': time += (hour < 10 ? '0' : '') + hour; break;
|
|
case 'i': time += (minutes < 10 ? '0' : '') + minutes; break;
|
|
case 's': time += '00';
|
|
default: time += c;
|
|
}
|
|
}
|
|
|
|
return time;
|
|
}
|
|
|
|
function sieve_form_init()
|
|
{
|
|
var form = rcmail.gui_objects.sieveform;
|
|
|
|
// resize dialog window
|
|
if (rcmail.env.action == 'plugin.managesieve' && rcmail.env.task == 'mail') {
|
|
parent.rcmail.managesieve_dialog_resize(form);
|
|
}
|
|
|
|
$('input[type="text"]', form).first().focus();
|
|
|
|
// initialize smart list inputs
|
|
$('textarea[data-type="list"]', form).each(function() {
|
|
smart_field_init(this);
|
|
});
|
|
|
|
// initialize rules form(s)
|
|
$('[name^="_header"]', form).each(function() {
|
|
if (/([0-9]+)$/.test(this.id)) {
|
|
rule_header_select(RegExp.$1);
|
|
}
|
|
});
|
|
|
|
// enable date pickers on date fields
|
|
if ($.datepicker && rcmail.env.date_format) {
|
|
$.datepicker.setDefaults({
|
|
dateFormat: rcmail.env.date_format,
|
|
changeMonth: true,
|
|
showOtherMonths: true,
|
|
selectOtherMonths: true,
|
|
onSelect: function(dateText) { $(this).focus().val(dateText); }
|
|
});
|
|
$('input.datepicker').datepicker();
|
|
}
|
|
|
|
// configure drop-down menu on time input fields based on jquery UI autocomplete
|
|
$('#vacation_timefrom, #vacation_timeto')
|
|
.attr('autocomplete', "off")
|
|
.autocomplete({
|
|
delay: 100,
|
|
minLength: 1,
|
|
source: function(p, callback) {
|
|
var h, result = [];
|
|
for (h = 0; h < 24; h++)
|
|
result.push(sieve_formattime(h, 0));
|
|
result.push(sieve_formattime(23, 59));
|
|
|
|
return callback(result);
|
|
},
|
|
open: function(event, ui) {
|
|
// scroll to current time
|
|
var $this = $(this), val = $this.val(),
|
|
widget = $this.autocomplete('widget').css('width', '10em'),
|
|
menu = $this.data('ui-autocomplete').menu;
|
|
|
|
if (val && val.length)
|
|
widget.children().each(function() {
|
|
var li = $(this);
|
|
if (li.text().indexOf(val) == 0)
|
|
menu._scrollIntoView(li);
|
|
});
|
|
},
|
|
select: function(event, ui) {
|
|
$(this).val(ui.item.value);
|
|
return false;
|
|
}
|
|
})
|
|
.click(function() { // show drop-down upon clicks
|
|
$(this).autocomplete('search', $(this).val() || ' ');
|
|
})
|
|
|
|
// display advanced controls when contain errors
|
|
$('input.error').each(function() {
|
|
if (String(this.id).match(/([0-9]+)$/)) {
|
|
$('#ruleadv' + RegExp.$1 + '.show').click();
|
|
}
|
|
});
|
|
}
|
|
|
|
/*********************************************************/
|
|
/********* RAW editor methods *********/
|
|
/*********************************************************/
|
|
|
|
var cmeditor;
|
|
|
|
function cmCreateErrorElem(msg)
|
|
{
|
|
var marker = document.createElement("div");
|
|
marker.style.color = "#822";
|
|
marker.innerHTML = "●";
|
|
marker.title = msg;
|
|
|
|
return marker;
|
|
}
|
|
|
|
function cmScrollToError()
|
|
{
|
|
var line = $('.CodeMirror-lines .line-error'),
|
|
scroll = $('.CodeMirror-scroll'),
|
|
h = line.parent();
|
|
|
|
scroll.scrollTop(line.offset().top - scroll.offset().top - Math.round(scroll.height()/2));
|
|
}
|
|
|
|
function sieve_raw_editor_init()
|
|
{
|
|
var textArea = document.getElementById('rawfiltersettxt');
|
|
if (textArea && !cmeditor) {
|
|
cmeditor = CodeMirror.fromTextArea(textArea, {
|
|
mode: 'sieve',
|
|
lineNumbers: true,
|
|
gutters: ["CodeMirror-linenumbers", "errorGutter"],
|
|
styleActiveLine: true
|
|
});
|
|
|
|
// fetching errors from environment and setting the line background
|
|
// and a gutter element with the error message accordingly
|
|
$.each(rcmail.env.sieve_errors || [], function(i, err) {
|
|
var lineNo = Number(err.line) - 1;
|
|
cmeditor.addLineClass(lineNo, 'background', 'line-error');
|
|
cmeditor.setGutterMarker(lineNo, 'errorGutter', cmCreateErrorElem(err.msg));
|
|
if (!i) cmScrollToError();
|
|
});
|
|
}
|
|
}
|
|
|
|
|
|
/*********************************************************/
|
|
/********* Mail UI methods *********/
|
|
/*********************************************************/
|
|
|
|
rcube_webmail.prototype.managesieve_create = function(force)
|
|
{
|
|
if (!force && this.env.action != 'show') {
|
|
var uid = this.message_list.get_single_selection(),
|
|
lock = this.set_busy(true, 'loading');
|
|
|
|
this.http_post('plugin.managesieve-action', {_uid: uid}, lock);
|
|
return;
|
|
}
|
|
|
|
if (!this.env.sieve_headers || !this.env.sieve_headers.length)
|
|
return;
|
|
|
|
var i, buttons = {},
|
|
title = this.get_label('managesieve.newfilter'),
|
|
dialog = $('<div id="sievefilterform" class="propform"></div>'),
|
|
props = {minWidth: 600, minHeight: 250, height: 300};
|
|
|
|
|
|
// build dialog window content
|
|
dialog.append($('<fieldset>')
|
|
.append($('<legend>').text(this.get_label('managesieve.usedata')))
|
|
.append($('<ul class="proplist">'))
|
|
);
|
|
|
|
$.each(this.env.sieve_headers, function(i, v) {
|
|
var attr = {type: 'checkbox', name: 'headers[]', id: 'sievehdr' + i, value: i, checked: true},
|
|
label = rcmail.env.sieve_headers[i][0] + ': ' + rcmail.env.sieve_headers[i][1];
|
|
|
|
$('ul', dialog).append($('<li>')
|
|
.append($('<input>').attr(attr))
|
|
.append($('<label>').attr('for', 'sievehdr' + i).text(label))
|
|
);
|
|
});
|
|
|
|
// [Next Step] button action
|
|
buttons[this.get_label('managesieve.nextstep')] = function () {
|
|
// check if there's at least one checkbox checked
|
|
var hdrs = $('input[name="headers[]"]:checked', dialog);
|
|
if (!hdrs.length) {
|
|
rcmail.alert_dialog(rcmail.get_label('managesieve.nodata'));
|
|
return;
|
|
}
|
|
|
|
// build frame URL
|
|
var url = rcmail.get_task_url('mail');
|
|
url = rcmail.add_url(url, '_action', 'plugin.managesieve');
|
|
url = rcmail.add_url(url, '_framed', 1);
|
|
|
|
hdrs.map(function() {
|
|
var val = rcmail.env.sieve_headers[this.value];
|
|
url = rcmail.add_url(url, 'r['+this.value+']', val[0]+':'+val[1]);
|
|
});
|
|
|
|
// load form in the iframe
|
|
var buttons = {}, iframe = $('<iframe>').attr({src: url, frameborder: 0});
|
|
|
|
// Change [Next Step] button with [Save] button
|
|
buttons[rcmail.get_label('save')] = function() {
|
|
var win = $('iframe', dialog).get(0).contentWindow;
|
|
win.rcmail.managesieve_save();
|
|
};
|
|
buttons[rcmail.get_label('cancel')] = function() { $(this).dialog('destroy'); };
|
|
|
|
dialog.dialog('destroy');
|
|
|
|
rcmail.env.managesieve_dialog = dialog = rcmail.show_popup_dialog(
|
|
iframe, title, buttons, $.extend(props, {button_classes: ['mainaction save', 'cancel']})
|
|
);
|
|
};
|
|
|
|
buttons[this.get_label('cancel')] = function() { $(this).dialog('destroy'); };
|
|
|
|
this.env.managesieve_dialog = dialog = this.show_popup_dialog(
|
|
dialog, title, buttons, $.extend(props, {button_classes: ['mainaction next', 'cancel']})
|
|
);
|
|
}
|
|
|
|
rcube_webmail.prototype.managesieve_dialog_close = function()
|
|
{
|
|
this.env.managesieve_dialog.dialog('destroy');
|
|
}
|
|
|
|
rcube_webmail.prototype.managesieve_dialog_resize = function(o)
|
|
{
|
|
var dialog = this.env.managesieve_dialog,
|
|
win = $(window), form = $(o);
|
|
width = $('fieldset', o).first().width(), // fieldset width is more appropriate here
|
|
height = form.height(),
|
|
w = win.width(), h = win.height();
|
|
|
|
if (height < 100)
|
|
return;
|
|
|
|
dialog.dialog('option', { height: Math.min(h-20, height+120), width: Math.min(w-20, width+65) });
|
|
}
|