Aleksander Machniak
2014-06-20 fc6dab3c6740092e8063f73d73d150b754376445
Fix regressions in popups handling (#1489932)
3 files modified
145 ■■■■ changed files
skins/classic/functions.js 138 ●●●● patch | view | raw | blame | history
skins/classic/mail.css 1 ●●●● patch | view | raw | blame | history
skins/classic/templates/mail.html 6 ●●●● patch | view | raw | blame | history
skins/classic/functions.js
@@ -106,7 +106,6 @@
    searchmenu:     {id:'searchmenu', editable:1},
    messagemenu:    {id:'messagemenu'},
    attachmentmenu: {id:'attachmentmenu'},
    listmenu:       {id:'listmenu', editable:1},
    dragmenu:       {id:'dragmenu', sticky:1},
    groupmenu:      {id:'groupoptionsmenu', above:1},
    mailboxmenu:    {id:'mailboxoptionsmenu', above:1},
@@ -293,61 +292,62 @@
  rcmail.set_searchmods(m);
},
listmenu: function(show)
show_listmenu: function(p)
{
  var obj = this.popups.listmenu.obj,
    ref = rcube_find_object('listmenulink');
  var self = this, buttons = {}, $dialog = $('#listmenu');
  if (typeof show == 'undefined')
    show = obj.is(':visible') ? false : true;
  if (show && ref) {
    var pos = $(ref).offset(),
      menuwidth = obj.width(),
      pagewidth = $(document).width();
    if (pagewidth - pos.left < menuwidth && pos.left > menuwidth)
      pos.left = pos.left - menuwidth;
    obj.css({ left:pos.left, top:(pos.top + ref.offsetHeight + 2)});
    // set form values
    $('input[name="sort_col"][value="'+rcmail.env.sort_col+'"]').prop('checked', true);
    $('input[name="sort_ord"][value="DESC"]').prop('checked', rcmail.env.sort_order == 'DESC');
    $('input[name="sort_ord"][value="ASC"]').prop('checked', rcmail.env.sort_order != 'DESC');
    $('input[name="view"][value="thread"]').prop('checked', rcmail.env.threading ? true : false);
    $('input[name="view"][value="list"]').prop('checked', rcmail.env.threading ? false : true);
    // set checkboxes
    $('input[name="list_col[]"]').each(function() {
      $(this).prop('checked', jQuery.inArray(this.value, rcmail.env.coltypes) != -1);
    });
  // close the dialog
  if ($dialog.is(':visible')) {
    $dialog.dialog('close', p.originalEvent);
    return;
  }
  obj[show?'show':'hide']();
  // set form values
  $('input[name="sort_col"][value="'+rcmail.env.sort_col+'"]').prop('checked', true);
  $('input[name="sort_ord"][value="DESC"]').prop('checked', rcmail.env.sort_order == 'DESC');
  $('input[name="sort_ord"][value="ASC"]').prop('checked', rcmail.env.sort_order != 'DESC');
  $('input[name="view"][value="thread"]').prop('checked', rcmail.env.threading ? true : false);
  $('input[name="view"][value="list"]').prop('checked', rcmail.env.threading ? false : true);
  if (show) {
    var maxheight=0;
    $('#listmenu fieldset').each(function() {
      var height = $(this).height();
      if (height > maxheight) {
        maxheight = height;
      }
    });
    $('#listmenu fieldset').css("min-height", maxheight+"px")
      .height(maxheight);
  // set checkboxes
  $('input[name="list_col[]"]').each(function() {
    $(this).prop('checked', $.inArray(this.value, rcmail.env.listcols) != -1);
  });
  buttons[rcmail.gettext('save')] = function(e) {
    $dialog.dialog('close', e);
    self.save_listmenu();
  };
},
open_listmenu: function()
{
  this.listmenu();
  $dialog.dialog({
    modal: true,
    resizable: false,
    closeOnEscape: true,
    title: null,
    open: function(e) {
      var maxheight = 0;
      $('#listmenu fieldset').each(function() {
        var height = $(this).height();
        if (height > maxheight) {
          maxheight = height;
        }
      }).css("min-height", maxheight+"px").height(maxheight);
      setTimeout(function() { $dialog.find('a, input:not(:disabled)').not('[aria-disabled=true]').first().focus(); }, 100);
    },
    close: function(e) {
      $dialog.dialog('destroy').hide();
      if (e.originalEvent && rcube_event.is_keyboard(e.originalEvent))
        $('#listmenulink').focus();
    },
    buttons: buttons,
    minWidth: 500,
    width: $dialog.width()+20
  }).show();
},
save_listmenu: function()
{
  this.listmenu();
  var sort = $('input[name="sort_col"]:checked').val(),
    ord = $('input[name="sort_ord"]:checked').val(),
    thread = $('input[name="view"]:checked').val(),
@@ -394,7 +394,7 @@
  this.show_popupmenu('spellmenu', show);
},
show_attachmentmenu: function(elem)
show_attachmentmenu: function(elem, event)
{
  var id = elem.parentNode.id.replace(/^attach/, '');
@@ -407,20 +407,13 @@
  });
  this.popups.attachmentmenu.link = elem;
  rcmail.command('menu-open', {menu: 'attachmentmenu', id: id});
  rcmail.command('menu-open', {menu: 'attachmentmenu', id: id}, elem, event);
},
menu_open: function(p)
{
  if (p && p.props && p.props.menu == 'attachmentmenu')
    this.show_popup('attachmentmenu');
  else
    this.open_listmenu();
},
menu_save: function(prop)
{
  this.save_listmenu();
  if (p && p.name == 'messagelistmenu')
    this.show_listmenu();
},
body_mouseup: function(e)
@@ -973,20 +966,19 @@
      .contents().mouseup(function(e) { rcmail_ui.body_mouseup(e); });
    if (rcmail.env.task == 'mail') {
      rcmail.addEventListener('enable-command', 'enable_command', rcmail_ui);
      rcmail.addEventListener('menu-open', 'menu_open', rcmail_ui);
      rcmail.addEventListener('menu-save', 'menu_save', rcmail_ui);
      rcmail.addEventListener('aftersend-attachment', 'uploadmenu', rcmail_ui);
      rcmail.addEventListener('aftertoggle-editor', 'resize_compose_body_ev', rcmail_ui);
      rcmail.gui_object('dragmenu', 'dragmenu');
      rcmail.addEventListener('enable-command', 'enable_command', rcmail_ui)
        .addEventListener('menu-open', 'menu_open', rcmail_ui)
        .addEventListener('aftersend-attachment', 'uploadmenu', rcmail_ui)
        .addEventListener('aftertoggle-editor', 'resize_compose_body_ev', rcmail_ui)
        .gui_object('dragmenu', 'dragmenu');
      if (rcmail.gui_objects.mailboxlist) {
        rcmail.treelist.addEventListener('expand', rcube_render_mailboxlist);
        rcmail.addEventListener('responseaftermark', rcube_render_mailboxlist);
        rcmail.addEventListener('responseaftergetunread', rcube_render_mailboxlist);
        rcmail.addEventListener('responseaftercheck-recent', rcube_render_mailboxlist);
        rcmail.addEventListener('responseafterrefresh', rcube_render_mailboxlist);
        rcmail.addEventListener('afterimport-messages', function(){ rcmail_ui.show_popup('uploadform', false); });
        rcmail.addEventListener('responseaftermark', rcube_render_mailboxlist)
          .addEventListener('responseaftergetunread', rcube_render_mailboxlist)
          .addEventListener('responseaftercheck-recent', rcube_render_mailboxlist)
          .addEventListener('responseafterrefresh', rcube_render_mailboxlist)
          .addEventListener('afterimport-messages', function(){ rcmail_ui.show_popup('uploadform', false); });
      }
      if (rcmail.env.action == 'compose')
@@ -994,13 +986,17 @@
      else if (rcmail.env.action == 'show' || rcmail.env.action == 'preview')
        // add menu link for each attachment
        $('#attachment-list > li[id^="attach"]').each(function() {
          $(this).append($('<a class="drop"></a>').click(function() { rcmail_ui.show_attachmentmenu(this); }));
          $(this).append($('<a class="drop"></a>').bind('click keypress', function(e) {
            if (e.type != 'keypress' || e.which == 13) {
              rcmail_ui.show_attachmentmenu(this, e);
              return false;
            }
          }));
        });
    }
    else if (rcmail.env.task == 'addressbook') {
      rcmail.addEventListener('afterupload-photo', function(){ rcmail_ui.show_popup('uploadform', false); });
      rcmail.gui_object('dragmenu', 'dragmenu');
      rcmail.addEventListener('afterupload-photo', function(){ rcmail_ui.show_popup('uploadform', false); })
        .gui_object('dragmenu', 'dragmenu');
    }
    else if (rcmail.env.task == 'settings') {
      if (rcmail.gui_objects.subscriptionlist)
skins/classic/mail.css
@@ -966,6 +966,7 @@
  cursor: pointer;
  overflow: hidden;
  text-indent: -5000px;
  display: block;
}
.messagelist tbody tr td.subject
skins/classic/templates/mail.html
@@ -148,7 +148,7 @@
  </ul>
</div>
<div id="listmenu" class="popupmenu">
<div id="listmenu" style="display: none">
<roundcube:if condition="env:threads" />
<fieldset class="thinbordered"><legend><roundcube:label name="listmode" /></legend>
  <ul class="toolbarmenu">
@@ -200,10 +200,6 @@
  </ul>
</fieldset>
<roundcube:endif />
<div>
  <roundcube:button command="menu-open" id="listmenucancel" type="input" class="button" label="cancel" />
  <roundcube:button command="menu-save" id="listmenusave" type="input" class="button mainaction" label="save" />
</div>
</div>
<roundcube:object name="messageimportform" id="upload-form" attachmentFieldSize="40" class="popupmenu" />