X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=lib%2Fsup%2Fmodes%2Finbox-mode.rb;h=ba095dab7c09696f60efb7e68c993d614da9e7b8;hb=d50ad629bc9321980abeaeeebf17a935c300a7b1;hp=719565bce1ef1be42b795b768d86b86f3f209ec3;hpb=1702e602130e157e30ee9aeb1399f0000d8d2062;p=sup diff --git a/lib/sup/modes/inbox-mode.rb b/lib/sup/modes/inbox-mode.rb index 719565b..ba095da 100644 --- a/lib/sup/modes/inbox-mode.rb +++ b/lib/sup/modes/inbox-mode.rb @@ -1,4 +1,4 @@ -require 'thread' +require 'sup' module Redwood @@ -6,17 +6,16 @@ class InboxMode < ThreadIndexMode register_keymap do |k| ## overwrite toggle_archived with archive k.add :archive, "Archive thread (remove from inbox)", 'a' + k.add :read_and_archive, "Archive thread (remove from inbox) and mark read", 'A' end def initialize - super [:inbox, :sent], { :label => :inbox, :skip_killed => true } + super [:inbox, :sent, :draft], { :label => :inbox, :skip_killed => true } raise "can't have more than one!" if defined? @@instance @@instance = self end - def is_relevant? m - m.has_label?(:inbox) && ([:spam, :deleted, :killed] & m.labels).empty? - end + def is_relevant? m; (m.labels & [:spam, :deleted, :killed, :inbox]) == Set.new([:inbox]) end ## label-list-mode wants to be able to raise us if the user selects ## the "inbox" label, so we need to keep our singletonness around @@ -25,12 +24,27 @@ class InboxMode < ThreadIndexMode def archive return unless cursor_thread + thread = cursor_thread # to make sure lambda only knows about 'old' cursor_thread + + UndoManager.register "archiving thread" do + thread.apply_label :inbox + add_or_unhide thread.first + end + cursor_thread.remove_label :inbox hide_thread cursor_thread regen_text end def multi_archive threads + UndoManager.register "archiving #{threads.size.pluralize 'thread'}" do + threads.map do |t| + t.apply_label :inbox + add_or_unhide t.first + end + regen_text + end + threads.each do |t| t.remove_label :inbox hide_thread t @@ -38,18 +52,51 @@ class InboxMode < ThreadIndexMode regen_text end - def handle_archived_update sender, t - if contains_thread? t + def read_and_archive + return unless cursor_thread + thread = cursor_thread # to make sure lambda only knows about 'old' cursor_thread + + UndoManager.register "reading and archiving thread" do + thread.apply_label :inbox + thread.apply_label :unread + add_or_unhide thread.first + end + + cursor_thread.remove_label :unread + cursor_thread.remove_label :inbox + hide_thread cursor_thread + regen_text + end + + def multi_read_and_archive threads + old_labels = threads.map { |t| t.labels.dup } + + threads.each do |t| + t.remove_label :unread + t.remove_label :inbox hide_thread t + end + regen_text + + UndoManager.register "reading and archiving #{threads.size.pluralize 'thread'}" do + threads.zip(old_labels).each do |t, l| + t.labels = l + add_or_unhide t.first + end regen_text end + + end + + def handle_unarchived_update sender, m + add_or_unhide m end -# not quite working, and not sure if i like it anyways -# def handle_unarchived_update sender, t -# Redwood::log "unarchived #{t.subj}" -# show_thread t -# end + def handle_archived_update sender, m + t = thread_containing(m) or return + hide_thread t + regen_text + end def status super + " #{Index.size} messages in index"