mirror of
				https://github.com/oxen-io/session-android.git
				synced 2025-10-26 03:00:47 +00:00 
			
		
		
		
	Add 'mark all as read' option
This commit is contained in:
		| @@ -2,25 +2,27 @@ package org.thoughtcrime.securesms; | ||||
|  | ||||
| import android.content.Intent; | ||||
| import android.database.ContentObserver; | ||||
| import android.os.AsyncTask; | ||||
| import android.os.Build; | ||||
| import android.os.Bundle; | ||||
| import android.provider.ContactsContract; | ||||
| import android.util.Log; | ||||
| import android.view.WindowManager; | ||||
|  | ||||
| import com.actionbarsherlock.view.Menu; | ||||
| import com.actionbarsherlock.view.MenuInflater; | ||||
| import com.actionbarsherlock.view.MenuItem; | ||||
| import org.thoughtcrime.securesms.ApplicationExportManager.ApplicationExportListener; | ||||
| import org.thoughtcrime.securesms.crypto.MasterSecret; | ||||
| import org.thoughtcrime.securesms.database.DatabaseFactory; | ||||
| import org.thoughtcrime.securesms.database.ThreadDatabase; | ||||
| import org.thoughtcrime.securesms.notifications.MessageNotifier; | ||||
| import org.thoughtcrime.securesms.recipients.RecipientFactory; | ||||
| import org.thoughtcrime.securesms.recipients.Recipients; | ||||
| import org.thoughtcrime.securesms.service.KeyCachingService; | ||||
| import org.thoughtcrime.securesms.service.SendReceiveService; | ||||
| import org.thoughtcrime.securesms.util.MemoryCleaner; | ||||
|  | ||||
| import com.actionbarsherlock.view.Menu; | ||||
| import com.actionbarsherlock.view.MenuInflater; | ||||
| import com.actionbarsherlock.view.MenuItem; | ||||
|  | ||||
| public class ConversationListActivity extends PassphraseRequiredSherlockFragmentActivity | ||||
|     implements ConversationListFragment.ConversationSelectedListener | ||||
|   { | ||||
| @@ -76,6 +78,7 @@ public class ConversationListActivity extends PassphraseRequiredSherlockFragment | ||||
|     case R.id.menu_export:           handleExportDatabase();                    return true; | ||||
|     case R.id.menu_import:           handleImportDatabase();                    return true; | ||||
|     case R.id.menu_clear_passphrase: handleClearPassphrase();                   return true; | ||||
|     case R.id.menu_mark_all_read:    handleMarkAllRead();                       return true; | ||||
|     } | ||||
|  | ||||
|     return false; | ||||
| @@ -127,6 +130,17 @@ public class ConversationListActivity extends PassphraseRequiredSherlockFragment | ||||
|     startService(intent); | ||||
|   } | ||||
|  | ||||
|   private void handleMarkAllRead() { | ||||
|     new AsyncTask<Void, Void, Void>() { | ||||
|       @Override | ||||
|       protected Void doInBackground(Void... params) { | ||||
|         DatabaseFactory.getThreadDatabase(ConversationListActivity.this).setAllThreadsRead(); | ||||
|         MessageNotifier.updateNotification(ConversationListActivity.this, masterSecret); | ||||
|         return null; | ||||
|       } | ||||
|     }.execute(); | ||||
|   } | ||||
|  | ||||
|   private void initializeContactUpdatesReceiver() { | ||||
|     ContentObserver observer = new ContentObserver(null) { | ||||
|       @Override | ||||
|   | ||||
| @@ -273,6 +273,14 @@ public class MmsDatabase extends Database implements MmsSmsColumns { | ||||
|     database.update(TABLE_NAME, contentValues, THREAD_ID + " = ?", new String[] {threadId+""}); | ||||
|   } | ||||
|  | ||||
|   public void setAllMessagesRead() { | ||||
|     SQLiteDatabase database     = databaseHelper.getWritableDatabase(); | ||||
|     ContentValues contentValues = new ContentValues(); | ||||
|     contentValues.put(READ, 1); | ||||
|  | ||||
|     database.update(TABLE_NAME, contentValues, null, null); | ||||
|   } | ||||
|  | ||||
|   public SendReq[] getOutgoingMessages(MasterSecret masterSecret, long messageId) | ||||
|       throws MmsException | ||||
|   { | ||||
|   | ||||
| @@ -182,11 +182,17 @@ public class SmsDatabase extends Database implements MmsSmsColumns { | ||||
|     ContentValues contentValues = new ContentValues(); | ||||
|     contentValues.put(READ, 1); | ||||
|  | ||||
|     long start = System.currentTimeMillis(); | ||||
|     database.update(TABLE_NAME, contentValues, THREAD_ID + " = ? AND " + READ + " = 0", new String[] {threadId+""}); | ||||
|     long end = System.currentTimeMillis(); | ||||
|     database.update(TABLE_NAME, contentValues, | ||||
|                     THREAD_ID + " = ? AND " + READ + " = 0", | ||||
|                     new String[] {threadId+""}); | ||||
|   } | ||||
|  | ||||
|     Log.w("SmsDatabase", "setMessagesRead time: " + (end - start)); | ||||
|   public void setAllMessagesRead() { | ||||
|     SQLiteDatabase database     = databaseHelper.getWritableDatabase(); | ||||
|     ContentValues contentValues = new ContentValues(); | ||||
|     contentValues.put(READ, 1); | ||||
|  | ||||
|     database.update(TABLE_NAME, contentValues, null, null); | ||||
|   } | ||||
|  | ||||
|   protected void updateMessageBodyAndType(long messageId, String body, long maskOff, long maskOn) { | ||||
|   | ||||
| @@ -205,6 +205,18 @@ public class ThreadDatabase extends Database { | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   public void setAllThreadsRead() { | ||||
|     SQLiteDatabase db           = databaseHelper.getWritableDatabase(); | ||||
|     ContentValues contentValues = new ContentValues(1); | ||||
|     contentValues.put(READ, 1); | ||||
|  | ||||
|     db.update(TABLE_NAME, contentValues, null, null); | ||||
|  | ||||
|     DatabaseFactory.getSmsDatabase(context).setAllMessagesRead(); | ||||
|     DatabaseFactory.getMmsDatabase(context).setAllMessagesRead(); | ||||
|     notifyConversationListListeners(); | ||||
|   } | ||||
|  | ||||
|   public void setRead(long threadId) { | ||||
|     ContentValues contentValues = new ContentValues(1); | ||||
|     contentValues.put(READ, 1); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Moxie Marlinspike
					Moxie Marlinspike