Skip to content

Commit

Permalink
(feat) reworked batch menu + added save messages option
Browse files Browse the repository at this point in the history
  • Loading branch information
extrafu committed Aug 5, 2015
1 parent 124ca5d commit a220ee6
Show file tree
Hide file tree
Showing 3 changed files with 35 additions and 10 deletions.
2 changes: 1 addition & 1 deletion UI/MailerUI/UIxMailFolderActions.m
Expand Up @@ -313,7 +313,7 @@ - (WOResponse *) batchDeleteAction
data = [[request contentAsString] objectFromJSONString];
withTrash = ![[data objectForKey: @"withoutTrash"] boolValue];

if ((uids = [data objectForKey: @"uids"]) && [uids isKindOfClass: [NSArray class]] && [uids length] > 0)
if ((uids = [data objectForKey: @"uids"]) && [uids isKindOfClass: [NSArray class]] && [uids count] > 0)
{
response = (WOResponse *) [co deleteUIDs: uids useTrashFolder: &withTrash inContext: context];
if (!response)
Expand Down
30 changes: 24 additions & 6 deletions UI/Templates/MailerUI/UIxMailMainFrame.wox
Expand Up @@ -438,19 +438,15 @@
</md-button>
<label>{{mailbox.selectedFolder.$selectedCount()}} selected</label>
<md-button class="sg-icon-button" ng-click="mailbox.selectAll()">
<md-tooltip md-direction="left"><var:string label:value="Select All"/></md-tooltip>
<md-icon>select_all</md-icon>
</md-button>
<md-button class="sg-icon-button" ng-click="mailbox.confirmDeleteSelectedMessages()">
<md-icon>delete</md-icon>
</md-button>
<md-button class="sg-icon-button">
<md-icon>star</md-icon>
</md-button>
<md-button class="sg-icon-button">
<md-icon>markunread</md-icon>
</md-button>
<md-menu>
<md-button class="sg-icon-button" label:aria-label="Copy messages" ng-click="$mdOpenMenu()">
<md-tooltip md-direction="left"><var:string label:value="Copy To"/></md-tooltip>
<md-icon>content_copy</md-icon>
</md-button>
<md-menu-content width="4">
Expand All @@ -470,6 +466,28 @@
</div>
</md-menu-content>
</md-menu>
<md-menu>
<md-button class="sg-icon-button" label:aria-label="More messages options" ng-click="$mdOpenMenu()">
<md-icon>more_vert</md-icon>
</md-button>
<md-menu-content width="2">
<md-menu-item>
<md-button>
<var:string label:value="Flag"/>
</md-button>
</md-menu-item>
<md-menu-item>
<md-button>
<var:string label:value="Mark as Unread"/>
</md-button>
</md-menu-item>
<md-menu-item>
<md-button ng-click="mailbox.saveSelectedMessages()">
<var:string label:value="Save As..."/>
</md-button>
</md-menu-item>
</md-menu-content>
</md-menu>
</div>
</md-toolbar>
<div layout="row" class="md-flex">
Expand Down
13 changes: 10 additions & 3 deletions UI/WebServerResources/js/Mailer/MailboxController.js
Expand Up @@ -21,6 +21,7 @@
vm.confirmDeleteSelectedMessages = confirmDeleteSelectedMessages;
vm.copySelectedMessages = copySelectedMessages;
// vm.moveSelectedMessages = moveSelectedMessages;
vm.saveSelectedMessages = saveSelectedMessages;
vm.selectAll = selectAll;
vm.sort = sort;
vm.sortedBy = sortedBy;
Expand All @@ -45,9 +46,9 @@
var selectedUIDs = _.pluck(selectedMessages, 'uid');
vm.selectedFolder.$deleteMessages(selectedUIDs).then(function() {
vm.selectedFolder.$messages = _.difference(vm.selectedFolder.$messages, selectedMessages);
}, function(error) {
Dialog.alert(l('Error'), error);
});
}, function(data, status) {
// Delete failed
});
}

Expand All @@ -57,7 +58,7 @@
vm.selectedFolder.$copyMessages(selectedUIDs, '/' + folder).then(function() {
// TODO: refresh target mailbox?
}, function(error) {
Dialog.alert(l('Error'), error.error);
Dialog.alert(l('Error'), error);
});
}

Expand All @@ -70,6 +71,12 @@
// });
// }

function saveSelectedMessages() {
var selectedMessages = _.filter(vm.selectedFolder.$messages, function(message) { return message.selected; });
var selectedUIDs = _.pluck(selectedMessages, 'uid');
window.location.href = ApplicationBaseURL + '/' + vm.selectedFolder.id + '/saveMessages?uid=' + selectedUIDs.join(",");
}

function selectAll() {
_.each(vm.selectedFolder.$messages, function(message) {
message.selected = true;
Expand Down

0 comments on commit a220ee6

Please sign in to comment.