5 class InboxMode < ThreadIndexMode
7 ## overwrite toggle_archived with archive
8 k.add :archive, "Archive thread (remove from inbox)", 'a'
9 k.add :read_and_archive, "Archive thread (remove from inbox) and mark read", 'A'
13 super [:inbox, :sent, :draft], { :label => :inbox, :skip_killed => true }
14 raise "can't have more than one!" if defined? @@instance
18 def is_relevant? m; (m.labels & [:spam, :deleted, :killed, :inbox]) == Set.new([:inbox]) end
20 ## label-list-mode wants to be able to raise us if the user selects
21 ## the "inbox" label, so we need to keep our singletonness around
22 def self.instance; @@instance; end
23 def killable?; false; end
26 return unless cursor_thread
27 thread = cursor_thread # to make sure lambda only knows about 'old' cursor_thread
29 UndoManager.register "archiving thread" do
30 thread.apply_label :inbox
31 add_or_unhide thread.first
34 cursor_thread.remove_label :inbox
35 hide_thread cursor_thread
39 def multi_archive threads
40 UndoManager.register "archiving #{threads.size.pluralize 'thread'}" do
56 return unless cursor_thread
57 thread = cursor_thread # to make sure lambda only knows about 'old' cursor_thread
59 UndoManager.register "reading and archiving thread" do
60 thread.apply_label :inbox
61 thread.apply_label :unread
62 add_or_unhide thread.first
65 cursor_thread.remove_label :unread
66 cursor_thread.remove_label :inbox
67 hide_thread cursor_thread
71 def multi_read_and_archive threads
72 old_labels = threads.map { |t| t.labels.dup }
75 t.remove_label :unread
81 UndoManager.register "reading and archiving #{threads.size.pluralize 'thread'}" do
82 threads.zip(old_labels).each do |t, l|
91 def handle_unarchived_update sender, m
95 def handle_archived_update sender, m
96 t = thread_containing(m) or return
102 super + " #{Index.size} messages in index"