A lot of features (may be unstable, don't upload to markets)
Blocked contacts Media auto download Repeat notifications every hour Vibration patterns Resend messages after app restart
This commit is contained in:
parent
8f7652bb7e
commit
fc46daa50f
@ -17,7 +17,7 @@ tasks.withType(JavaCompile) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
compile 'com.android.support:support-v4:19.0.+'
|
compile 'com.android.support:support-v4:20.0.+'
|
||||||
compile 'com.google.android.gms:play-services:3.2.+'
|
compile 'com.google.android.gms:play-services:3.2.+'
|
||||||
compile 'net.hockeyapp.android:HockeySDK:3.0.1'
|
compile 'net.hockeyapp.android:HockeySDK:3.0.1'
|
||||||
compile 'com.googlecode.mp4parser:isoparser:1.0.+'
|
compile 'com.googlecode.mp4parser:isoparser:1.0.+'
|
||||||
@ -27,9 +27,6 @@ android {
|
|||||||
compileSdkVersion 19
|
compileSdkVersion 19
|
||||||
buildToolsVersion '19.1.0'
|
buildToolsVersion '19.1.0'
|
||||||
|
|
||||||
useAaptPngCruncher = true
|
|
||||||
useOldManifestMerger true
|
|
||||||
|
|
||||||
signingConfigs {
|
signingConfigs {
|
||||||
debug {
|
debug {
|
||||||
storeFile file("config/debug.keystore")
|
storeFile file("config/debug.keystore")
|
||||||
@ -83,7 +80,7 @@ android {
|
|||||||
defaultConfig {
|
defaultConfig {
|
||||||
minSdkVersion 8
|
minSdkVersion 8
|
||||||
targetSdkVersion 19
|
targetSdkVersion 19
|
||||||
versionCode 307
|
versionCode 308
|
||||||
versionName "1.7.0"
|
versionName "1.8.0"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -138,6 +138,7 @@
|
|||||||
</service>
|
</service>
|
||||||
|
|
||||||
<service android:name="org.telegram.android.NotificationsService" android:enabled="true"/>
|
<service android:name="org.telegram.android.NotificationsService" android:enabled="true"/>
|
||||||
|
<service android:name="org.telegram.android.NotificationRepeat" android:exported="false"/>
|
||||||
|
|
||||||
<receiver android:name="org.telegram.android.AppStartReceiver" android:enabled="true">
|
<receiver android:name="org.telegram.android.AppStartReceiver" android:enabled="true">
|
||||||
<intent-filter>
|
<intent-filter>
|
||||||
|
@ -225,4 +225,8 @@ public class AndroidUtilities {
|
|||||||
public static long makeBroadcastId(int id) {
|
public static long makeBroadcastId(int id) {
|
||||||
return 0x0000000100000000L | ((long)id & 0x00000000FFFFFFFFL);
|
return 0x0000000100000000L | ((long)id & 0x00000000FFFFFFFFL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static void RunOnUIThread(Runnable runnable) {
|
||||||
|
ApplicationLoader.applicationHandler.post(runnable);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -12,12 +12,11 @@ import android.content.BroadcastReceiver;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
|
|
||||||
import org.telegram.messenger.Utilities;
|
|
||||||
import org.telegram.ui.ApplicationLoader;
|
import org.telegram.ui.ApplicationLoader;
|
||||||
|
|
||||||
public class AppStartReceiver extends BroadcastReceiver {
|
public class AppStartReceiver extends BroadcastReceiver {
|
||||||
public void onReceive(Context context, Intent intent) {
|
public void onReceive(Context context, Intent intent) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
ApplicationLoader.startPushService();
|
ApplicationLoader.startPushService();
|
||||||
|
@ -23,7 +23,6 @@ import org.telegram.PhoneFormat.PhoneFormat;
|
|||||||
import org.telegram.messenger.BuildVars;
|
import org.telegram.messenger.BuildVars;
|
||||||
import org.telegram.messenger.ConnectionsManager;
|
import org.telegram.messenger.ConnectionsManager;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.RPCRequest;
|
import org.telegram.messenger.RPCRequest;
|
||||||
import org.telegram.messenger.TLObject;
|
import org.telegram.messenger.TLObject;
|
||||||
@ -420,7 +419,7 @@ public class ContactsController {
|
|||||||
FileLog.e("tmessages", "detected account deletion!");
|
FileLog.e("tmessages", "detected account deletion!");
|
||||||
currentAccount = new Account(UserConfig.getCurrentUser().phone, "org.telegram.account");
|
currentAccount = new Account(UserConfig.getCurrentUser().phone, "org.telegram.account");
|
||||||
am.addAccountExplicitly(currentAccount, "", null);
|
am.addAccountExplicitly(currentAccount, "", null);
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
performWriteContactsToPhoneBook();
|
performWriteContactsToPhoneBook();
|
||||||
@ -547,7 +546,7 @@ public class ContactsController {
|
|||||||
MessagesStorage.getInstance().putCachedPhoneBook(contactsMap);
|
MessagesStorage.getInstance().putCachedPhoneBook(contactsMap);
|
||||||
}
|
}
|
||||||
if (!disableDeletion && !contactHashMap.isEmpty()) {
|
if (!disableDeletion && !contactHashMap.isEmpty()) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
if (BuildVars.DEBUG_VERSION) {
|
if (BuildVars.DEBUG_VERSION) {
|
||||||
@ -567,7 +566,7 @@ public class ContactsController {
|
|||||||
final HashMap<String, TLRPC.User> contactsPhonesShort = new HashMap<String, TLRPC.User>();
|
final HashMap<String, TLRPC.User> contactsPhonesShort = new HashMap<String, TLRPC.User>();
|
||||||
|
|
||||||
for (TLRPC.TL_contact value : contacts) {
|
for (TLRPC.TL_contact value : contacts) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(value.user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(value.user_id);
|
||||||
if (user == null || user.phone == null || user.phone.length() == 0) {
|
if (user == null || user.phone == null || user.phone.length() == 0) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -703,11 +702,11 @@ public class ContactsController {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
updateUnregisteredContacts(contacts);
|
updateUnregisteredContacts(contacts);
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.contactsDidLoaded);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.contactsDidLoaded);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -764,13 +763,13 @@ public class ContactsController {
|
|||||||
applyContactsUpdates(delayedContactsUpdate, null, null, null);
|
applyContactsUpdates(delayedContactsUpdate, null, null, null);
|
||||||
delayedContactsUpdate.clear();
|
delayedContactsUpdate.clear();
|
||||||
}
|
}
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
synchronized (loadContactsSync) {
|
synchronized (loadContactsSync) {
|
||||||
loadingContacts = false;
|
loadingContacts = false;
|
||||||
}
|
}
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.contactsDidLoaded);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.contactsDidLoaded);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
FileLog.e("tmessages", "load contacts don't change");
|
FileLog.e("tmessages", "load contacts don't change");
|
||||||
@ -785,19 +784,10 @@ public class ContactsController {
|
|||||||
|
|
||||||
public void processLoadedContacts(final ArrayList<TLRPC.TL_contact> contactsArr, final ArrayList<TLRPC.User> usersArr, final int from) {
|
public void processLoadedContacts(final ArrayList<TLRPC.TL_contact> contactsArr, final ArrayList<TLRPC.User> usersArr, final int from) {
|
||||||
//from: 0 - from server, 1 - from db, 2 - from imported contacts
|
//from: 0 - from server, 1 - from db, 2 - from imported contacts
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
for (TLRPC.User user : usersArr) {
|
MessagesController.getInstance().putUsers(usersArr, from == 1);
|
||||||
if (from == 1) {
|
|
||||||
MessagesController.getInstance().users.putIfAbsent(user.id, user);
|
|
||||||
} else {
|
|
||||||
MessagesController.getInstance().users.put(user.id, user);
|
|
||||||
if (user.id == UserConfig.getClientUserId()) {
|
|
||||||
UserConfig.setCurrentUser(user);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
final HashMap<Integer, TLRPC.User> usersDict = new HashMap<Integer, TLRPC.User>();
|
final HashMap<Integer, TLRPC.User> usersDict = new HashMap<Integer, TLRPC.User>();
|
||||||
|
|
||||||
@ -813,7 +803,7 @@ public class ContactsController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (TLRPC.TL_contact contact : contactsArr) {
|
for (TLRPC.TL_contact contact : contactsArr) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(contact.user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(contact.user_id);
|
||||||
if (user != null) {
|
if (user != null) {
|
||||||
usersDict.put(user.id, user);
|
usersDict.put(user.id, user);
|
||||||
|
|
||||||
@ -938,7 +928,7 @@ public class ContactsController {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
contacts = contactsArr;
|
contacts = contactsArr;
|
||||||
@ -953,7 +943,7 @@ public class ContactsController {
|
|||||||
performWriteContactsToPhoneBook();
|
performWriteContactsToPhoneBook();
|
||||||
updateUnregisteredContacts(contactsArr);
|
updateUnregisteredContacts(contactsArr);
|
||||||
|
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.contactsDidLoaded);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.contactsDidLoaded);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -963,7 +953,7 @@ public class ContactsController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (contactsByPhonesDictFinal != null) {
|
if (contactsByPhonesDictFinal != null) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
Utilities.globalQueue.postRunnable(new Runnable() {
|
Utilities.globalQueue.postRunnable(new Runnable() {
|
||||||
@ -992,7 +982,7 @@ public class ContactsController {
|
|||||||
final HashMap<String, TLRPC.TL_contact> contactsPhonesShort = new HashMap<String, TLRPC.TL_contact>();
|
final HashMap<String, TLRPC.TL_contact> contactsPhonesShort = new HashMap<String, TLRPC.TL_contact>();
|
||||||
|
|
||||||
for (TLRPC.TL_contact value : contactsArr) {
|
for (TLRPC.TL_contact value : contactsArr) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(value.user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(value.user_id);
|
||||||
if (user == null || user.phone == null || user.phone.length() == 0) {
|
if (user == null || user.phone == null || user.phone.length() == 0) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -1079,8 +1069,8 @@ public class ContactsController {
|
|||||||
Collections.sort(contacts, new Comparator<TLRPC.TL_contact>() {
|
Collections.sort(contacts, new Comparator<TLRPC.TL_contact>() {
|
||||||
@Override
|
@Override
|
||||||
public int compare(TLRPC.TL_contact tl_contact, TLRPC.TL_contact tl_contact2) {
|
public int compare(TLRPC.TL_contact tl_contact, TLRPC.TL_contact tl_contact2) {
|
||||||
TLRPC.User user1 = MessagesController.getInstance().users.get(tl_contact.user_id);
|
TLRPC.User user1 = MessagesController.getInstance().getUser(tl_contact.user_id);
|
||||||
TLRPC.User user2 = MessagesController.getInstance().users.get(tl_contact2.user_id);
|
TLRPC.User user2 = MessagesController.getInstance().getUser(tl_contact2.user_id);
|
||||||
String name1 = user1.first_name;
|
String name1 = user1.first_name;
|
||||||
if (name1 == null || name1.length() == 0) {
|
if (name1 == null || name1.length() == 0) {
|
||||||
name1 = user1.last_name;
|
name1 = user1.last_name;
|
||||||
@ -1099,7 +1089,7 @@ public class ContactsController {
|
|||||||
final ArrayList<String> sortedSectionsArray = new ArrayList<String>();
|
final ArrayList<String> sortedSectionsArray = new ArrayList<String>();
|
||||||
|
|
||||||
for (TLRPC.TL_contact value : contacts) {
|
for (TLRPC.TL_contact value : contacts) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(value.user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(value.user_id);
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -1162,7 +1152,7 @@ public class ContactsController {
|
|||||||
|
|
||||||
for (TLRPC.TL_contact u : contactsArray) {
|
for (TLRPC.TL_contact u : contactsArray) {
|
||||||
if (!bookContacts.containsKey(u.user_id)) {
|
if (!bookContacts.containsKey(u.user_id)) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(u.user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(u.user_id);
|
||||||
addContactToPhoneBook(user, false);
|
addContactToPhoneBook(user, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1209,9 +1199,9 @@ public class ContactsController {
|
|||||||
user = userDict.get(newContact.user_id);
|
user = userDict.get(newContact.user_id);
|
||||||
}
|
}
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
user = MessagesController.getInstance().users.get(newContact.user_id);
|
user = MessagesController.getInstance().getUser(newContact.user_id);
|
||||||
} else {
|
} else {
|
||||||
MessagesController.getInstance().users.putIfAbsent(user.id, user);
|
MessagesController.getInstance().putUser(user, true);
|
||||||
}
|
}
|
||||||
if (user == null || user.phone == null || user.phone.length() == 0) {
|
if (user == null || user.phone == null || user.phone.length() == 0) {
|
||||||
reloadContacts = true;
|
reloadContacts = true;
|
||||||
@ -1244,9 +1234,9 @@ public class ContactsController {
|
|||||||
user = userDict.get(uid);
|
user = userDict.get(uid);
|
||||||
}
|
}
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
user = MessagesController.getInstance().users.get(uid);
|
user = MessagesController.getInstance().getUser(uid);
|
||||||
} else {
|
} else {
|
||||||
MessagesController.getInstance().users.putIfAbsent(user.id, user);
|
MessagesController.getInstance().putUser(user, true);
|
||||||
}
|
}
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
reloadContacts = true;
|
reloadContacts = true;
|
||||||
@ -1282,7 +1272,7 @@ public class ContactsController {
|
|||||||
} else {
|
} else {
|
||||||
final ArrayList<TLRPC.TL_contact> newContacts = newC;
|
final ArrayList<TLRPC.TL_contact> newContacts = newC;
|
||||||
final ArrayList<Integer> contactsToDelete = contactsTD;
|
final ArrayList<Integer> contactsToDelete = contactsTD;
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
for (TLRPC.TL_contact contact : newContacts) {
|
for (TLRPC.TL_contact contact : newContacts) {
|
||||||
@ -1304,7 +1294,7 @@ public class ContactsController {
|
|||||||
}
|
}
|
||||||
performSyncPhoneBook(getContactsCopy(contactsBook), false, false, false);
|
performSyncPhoneBook(getContactsCopy(contactsBook), false, false, false);
|
||||||
buildContactsSectionsArrays(!newContacts.isEmpty());
|
buildContactsSectionsArrays(!newContacts.isEmpty());
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.contactsDidLoaded);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.contactsDidLoaded);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -1487,11 +1477,11 @@ public class ContactsController {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
for (TLRPC.User u : res.users) {
|
for (TLRPC.User u : res.users) {
|
||||||
MessagesController.getInstance().users.put(u.id, u);
|
MessagesController.getInstance().putUser(u, false);
|
||||||
if (contactsDict.get(u.id) == null) {
|
if (contactsDict.get(u.id) == null) {
|
||||||
TLRPC.TL_contact newContact = new TLRPC.TL_contact();
|
TLRPC.TL_contact newContact = new TLRPC.TL_contact();
|
||||||
newContact.user_id = u.id;
|
newContact.user_id = u.id;
|
||||||
@ -1500,7 +1490,7 @@ public class ContactsController {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
buildContactsSectionsArrays(true);
|
buildContactsSectionsArrays(true);
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.contactsDidLoaded);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.contactsDidLoaded);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -1551,7 +1541,7 @@ public class ContactsController {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
boolean remove = false;
|
boolean remove = false;
|
||||||
@ -1566,8 +1556,8 @@ public class ContactsController {
|
|||||||
if (remove) {
|
if (remove) {
|
||||||
buildContactsSectionsArrays(false);
|
buildContactsSectionsArrays(false);
|
||||||
}
|
}
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.updateInterfaces, MessagesController.UPDATE_MASK_NAME);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.updateInterfaces, MessagesController.UPDATE_MASK_NAME);
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.contactsDidLoaded);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.contactsDidLoaded);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,17 @@
|
|||||||
|
/*
|
||||||
|
* This is the source code of Telegram for Android v. 1.7.x.
|
||||||
|
* It is licensed under GNU GPL v. 2 or later.
|
||||||
|
* You should have received a copy of the license in this archive (see LICENSE).
|
||||||
|
*
|
||||||
|
* Copyright Nikolai Kudashov, 2013-2014.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.telegram.android;
|
||||||
|
|
||||||
|
import org.telegram.messenger.TLObject;
|
||||||
|
|
||||||
|
public class DownloadObject {
|
||||||
|
public TLObject object;
|
||||||
|
public int type;
|
||||||
|
public long id;
|
||||||
|
}
|
@ -27,7 +27,6 @@ import android.view.ViewGroup;
|
|||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.ui.ApplicationLoader;
|
import org.telegram.ui.ApplicationLoader;
|
||||||
|
|
||||||
@ -271,11 +270,11 @@ public class Emoji {
|
|||||||
Utilities.loadBitmap(imageFile.getAbsolutePath(), bitmap, imageResize, 0, width, height);
|
Utilities.loadBitmap(imageFile.getAbsolutePath(), bitmap, imageResize, 0, width, height);
|
||||||
|
|
||||||
final EmojiBitmap emojiBitmap = new EmojiBitmap(bitmap, width, height);
|
final EmojiBitmap emojiBitmap = new EmojiBitmap(bitmap, width, height);
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
emojiBmp[page] = emojiBitmap;
|
emojiBmp[page] = emojiBitmap;
|
||||||
NotificationCenter.getInstance().postNotificationName(999);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.emojiDidLoaded);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
} catch(Throwable x) {
|
} catch(Throwable x) {
|
||||||
|
@ -29,7 +29,7 @@ public class GcmBroadcastReceiver extends BroadcastReceiver {
|
|||||||
FileLog.d("tmessages", "GCM received intent: " + intent);
|
FileLog.d("tmessages", "GCM received intent: " + intent);
|
||||||
|
|
||||||
if (intent.getAction().equals("com.google.android.c2dm.intent.RECEIVE")) {
|
if (intent.getAction().equals("com.google.android.c2dm.intent.RECEIVE")) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
ApplicationLoader.postInitApplication();
|
ApplicationLoader.postInitApplication();
|
||||||
|
1004
TMessagesProj/src/main/java/org/telegram/android/ImageLoader.java
Normal file
1004
TMessagesProj/src/main/java/org/telegram/android/ImageLoader.java
Normal file
File diff suppressed because it is too large
Load Diff
@ -6,7 +6,7 @@
|
|||||||
* Copyright Nikolai Kudashov, 2013.
|
* Copyright Nikolai Kudashov, 2013.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.telegram.ui.Views;
|
package org.telegram.android;
|
||||||
|
|
||||||
import android.graphics.Bitmap;
|
import android.graphics.Bitmap;
|
||||||
import android.graphics.Canvas;
|
import android.graphics.Canvas;
|
||||||
@ -16,7 +16,6 @@ import android.graphics.drawable.Drawable;
|
|||||||
import android.view.View;
|
import android.view.View;
|
||||||
|
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.messenger.FileLoader;
|
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
|
|
||||||
@ -29,13 +28,21 @@ public class ImageReceiver {
|
|||||||
private String currentPath = null;
|
private String currentPath = null;
|
||||||
private boolean isPlaceholder = false;
|
private boolean isPlaceholder = false;
|
||||||
private Drawable currentImage = null;
|
private Drawable currentImage = null;
|
||||||
public Integer TAG = null;
|
private Integer tag = null;
|
||||||
public View parentView = null;
|
private View parentView = null;
|
||||||
public int imageX = 0, imageY = 0, imageW = 0, imageH = 0;
|
private int imageX = 0, imageY = 0, imageW = 0, imageH = 0;
|
||||||
public Rect drawRegion = new Rect();
|
private Rect drawRegion = new Rect();
|
||||||
private boolean isVisible = true;
|
private boolean isVisible = true;
|
||||||
private boolean selfSetting = false;
|
private boolean selfSetting = false;
|
||||||
public boolean isAspectFit = false;
|
private boolean isAspectFit = false;
|
||||||
|
|
||||||
|
public ImageReceiver() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public ImageReceiver(View view) {
|
||||||
|
parentView = view;
|
||||||
|
}
|
||||||
|
|
||||||
public void setImage(TLRPC.FileLocation path, String filter, Drawable placeholder) {
|
public void setImage(TLRPC.FileLocation path, String filter, Drawable placeholder) {
|
||||||
setImage(path, null, filter, placeholder, 0);
|
setImage(path, null, filter, placeholder, 0);
|
||||||
@ -49,8 +56,8 @@ public class ImageReceiver {
|
|||||||
setImage(null, path, filter, placeholder, 0);
|
setImage(null, path, filter, placeholder, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setImage(TLRPC.FileLocation path, String httpUrl, String filter, Drawable placeholder, int size) {
|
public void setImage(TLRPC.FileLocation fileLocation, String httpUrl, String filter, Drawable placeholder, int size) {
|
||||||
if ((path == null && httpUrl == null) || (path != null && !(path instanceof TLRPC.TL_fileLocation) && !(path instanceof TLRPC.TL_fileEncryptedLocation))) {
|
if ((fileLocation == null && httpUrl == null) || (fileLocation != null && !(fileLocation instanceof TLRPC.TL_fileLocation) && !(fileLocation instanceof TLRPC.TL_fileEncryptedLocation))) {
|
||||||
recycleBitmap(null);
|
recycleBitmap(null);
|
||||||
currentPath = null;
|
currentPath = null;
|
||||||
isPlaceholder = true;
|
isPlaceholder = true;
|
||||||
@ -60,44 +67,44 @@ public class ImageReceiver {
|
|||||||
last_placeholder = placeholder;
|
last_placeholder = placeholder;
|
||||||
last_size = 0;
|
last_size = 0;
|
||||||
currentImage = null;
|
currentImage = null;
|
||||||
FileLoader.getInstance().cancelLoadingForImageView(this);
|
ImageLoader.getInstance().cancelLoadingForImageView(this);
|
||||||
if (parentView != null) {
|
if (parentView != null) {
|
||||||
parentView.invalidate();
|
parentView.invalidate();
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
String key;
|
String key;
|
||||||
if (path != null) {
|
if (fileLocation != null) {
|
||||||
key = path.volume_id + "_" + path.local_id;
|
key = fileLocation.volume_id + "_" + fileLocation.local_id;
|
||||||
} else {
|
} else {
|
||||||
key = Utilities.MD5(httpUrl);
|
key = Utilities.MD5(httpUrl);
|
||||||
}
|
}
|
||||||
if (filter != null) {
|
if (filter != null) {
|
||||||
key += "@" + filter;
|
key += "@" + filter;
|
||||||
}
|
}
|
||||||
Bitmap img = null;
|
BitmapDrawable img = null;
|
||||||
if (currentPath != null) {
|
if (currentPath != null) {
|
||||||
if (currentPath.equals(key)) {
|
if (currentPath.equals(key)) {
|
||||||
if (currentImage != null) {
|
if (currentImage != null) {
|
||||||
return;
|
return;
|
||||||
} else {
|
} else {
|
||||||
img = FileLoader.getInstance().getImageFromMemory(path, httpUrl, this, filter);
|
img = ImageLoader.getInstance().getImageFromMemory(fileLocation, httpUrl, filter);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
img = FileLoader.getInstance().getImageFromMemory(path, httpUrl, this, filter);
|
img = ImageLoader.getInstance().getImageFromMemory(fileLocation, httpUrl, filter);
|
||||||
recycleBitmap(img);
|
recycleBitmap(img);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
img = FileLoader.getInstance().getImageFromMemory(path, httpUrl, this, filter);
|
img = ImageLoader.getInstance().getImageFromMemory(fileLocation, httpUrl, filter);
|
||||||
currentPath = key;
|
currentPath = key;
|
||||||
last_path = path;
|
last_path = fileLocation;
|
||||||
last_httpUrl = httpUrl;
|
last_httpUrl = httpUrl;
|
||||||
last_filter = filter;
|
last_filter = filter;
|
||||||
last_placeholder = placeholder;
|
last_placeholder = placeholder;
|
||||||
last_size = size;
|
last_size = size;
|
||||||
if (img == null) {
|
if (img == null) {
|
||||||
isPlaceholder = true;
|
isPlaceholder = true;
|
||||||
FileLoader.getInstance().loadImage(path, httpUrl, this, filter, true, size);
|
ImageLoader.getInstance().loadImage(fileLocation, httpUrl, this, size);
|
||||||
} else {
|
} else {
|
||||||
selfSetting = true;
|
selfSetting = true;
|
||||||
setImageBitmap(img, currentPath);
|
setImageBitmap(img, currentPath);
|
||||||
@ -108,20 +115,20 @@ public class ImageReceiver {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setImageBitmap(Bitmap bitmap, String imgKey) {
|
public void setImageBitmap(BitmapDrawable bitmap, String imgKey) {
|
||||||
if (currentPath == null || !imgKey.equals(currentPath)) {
|
if (currentPath == null || !imgKey.equals(currentPath)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
isPlaceholder = false;
|
isPlaceholder = false;
|
||||||
FileLoader.getInstance().incrementUseCount(currentPath);
|
ImageLoader.getInstance().incrementUseCount(currentPath);
|
||||||
currentImage = new BitmapDrawable(null, bitmap);
|
currentImage = bitmap;
|
||||||
if (!selfSetting && parentView != null) {
|
if (!selfSetting && parentView != null) {
|
||||||
parentView.invalidate();
|
parentView.invalidate();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setImageBitmap(Bitmap bitmap) {
|
public void setImageBitmap(Bitmap bitmap) {
|
||||||
FileLoader.getInstance().cancelLoadingForImageView(this);
|
ImageLoader.getInstance().cancelLoadingForImageView(this);
|
||||||
recycleBitmap(null);
|
recycleBitmap(null);
|
||||||
if (bitmap != null) {
|
if (bitmap != null) {
|
||||||
last_placeholder = new BitmapDrawable(null, bitmap);
|
last_placeholder = new BitmapDrawable(null, bitmap);
|
||||||
@ -141,7 +148,7 @@ public class ImageReceiver {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void setImageBitmap(Drawable bitmap) {
|
public void setImageBitmap(Drawable bitmap) {
|
||||||
FileLoader.getInstance().cancelLoadingForImageView(this);
|
ImageLoader.getInstance().cancelLoadingForImageView(this);
|
||||||
recycleBitmap(null);
|
recycleBitmap(null);
|
||||||
last_placeholder = bitmap;
|
last_placeholder = bitmap;
|
||||||
isPlaceholder = true;
|
isPlaceholder = true;
|
||||||
@ -160,18 +167,18 @@ public class ImageReceiver {
|
|||||||
recycleBitmap(null);
|
recycleBitmap(null);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void recycleBitmap(Bitmap newBitmap) {
|
private void recycleBitmap(BitmapDrawable newBitmap) {
|
||||||
if (currentImage == null || isPlaceholder) {
|
if (currentImage == null || isPlaceholder) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (currentImage instanceof BitmapDrawable) {
|
if (currentImage instanceof BitmapDrawable) {
|
||||||
Bitmap bitmap = ((BitmapDrawable)currentImage).getBitmap();
|
if (currentImage != newBitmap) {
|
||||||
if (bitmap != null && bitmap != newBitmap) {
|
|
||||||
if (currentPath != null) {
|
if (currentPath != null) {
|
||||||
boolean canDelete = FileLoader.getInstance().decrementUseCount(currentPath);
|
Bitmap bitmap = ((BitmapDrawable) currentImage).getBitmap();
|
||||||
if (!FileLoader.getInstance().isInCache(currentPath)) {
|
boolean canDelete = ImageLoader.getInstance().decrementUseCount(currentPath);
|
||||||
if (FileLoader.getInstance().runtimeHack != null) {
|
if (!ImageLoader.getInstance().isInCache(currentPath)) {
|
||||||
FileLoader.getInstance().runtimeHack.trackAlloc(bitmap.getRowBytes() * bitmap.getHeight());
|
if (ImageLoader.getInstance().runtimeHack != null) {
|
||||||
|
ImageLoader.getInstance().runtimeHack.trackAlloc(bitmap.getRowBytes() * bitmap.getHeight());
|
||||||
}
|
}
|
||||||
if (canDelete) {
|
if (canDelete) {
|
||||||
currentImage = null;
|
currentImage = null;
|
||||||
@ -242,7 +249,7 @@ public class ImageReceiver {
|
|||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
if (currentPath != null) {
|
if (currentPath != null) {
|
||||||
FileLoader.getInstance().removeImage(currentPath);
|
ImageLoader.getInstance().removeImage(currentPath);
|
||||||
currentPath = null;
|
currentPath = null;
|
||||||
}
|
}
|
||||||
setImage(last_path, last_httpUrl, last_filter, last_placeholder, last_size);
|
setImage(last_path, last_httpUrl, last_filter, last_placeholder, last_size);
|
||||||
@ -276,4 +283,59 @@ public class ImageReceiver {
|
|||||||
public boolean hasImage() {
|
public boolean hasImage() {
|
||||||
return currentImage != null || last_placeholder != null || currentPath != null || last_httpUrl != null;
|
return currentImage != null || last_placeholder != null || currentPath != null || last_httpUrl != null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setAspectFit(boolean value) {
|
||||||
|
isAspectFit = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setParentView(View view) {
|
||||||
|
parentView = view;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Integer getTag() {
|
||||||
|
return tag;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void setTag(Integer tag) {
|
||||||
|
this.tag = tag;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setImageCoords(int x, int y, int width, int height) {
|
||||||
|
imageX = x;
|
||||||
|
imageY = y;
|
||||||
|
imageW = width;
|
||||||
|
imageH = height;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getImageX() {
|
||||||
|
return imageX;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getImageY() {
|
||||||
|
return imageY;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getImageWidth() {
|
||||||
|
return imageW;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getImageHeight() {
|
||||||
|
return imageH;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isInsideImage(float x, float y) {
|
||||||
|
return x >= imageX && x <= imageX + imageW && y >= imageY && y <= imageY + imageH;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Rect getDrawRegion() {
|
||||||
|
return drawRegion;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getFilter() {
|
||||||
|
return last_filter;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getKey() {
|
||||||
|
return currentPath;
|
||||||
|
}
|
||||||
}
|
}
|
@ -6,9 +6,9 @@
|
|||||||
* Copyright Nikolai Kudashov, 2013.
|
* Copyright Nikolai Kudashov, 2013.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.telegram.messenger;
|
package org.telegram.android;
|
||||||
|
|
||||||
import android.graphics.Bitmap;
|
import android.graphics.drawable.BitmapDrawable;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.LinkedHashMap;
|
import java.util.LinkedHashMap;
|
||||||
@ -22,7 +22,7 @@ import java.util.Map;
|
|||||||
* overview.
|
* overview.
|
||||||
*/
|
*/
|
||||||
public class LruCache {
|
public class LruCache {
|
||||||
private final LinkedHashMap<String, Bitmap> map;
|
private final LinkedHashMap<String, BitmapDrawable> map;
|
||||||
private final LinkedHashMap<String, ArrayList<String>> mapFilters;
|
private final LinkedHashMap<String, ArrayList<String>> mapFilters;
|
||||||
|
|
||||||
/** Size of this cache in units. Not necessarily the number of elements. */
|
/** Size of this cache in units. Not necessarily the number of elements. */
|
||||||
@ -44,7 +44,7 @@ public class LruCache {
|
|||||||
throw new IllegalArgumentException("maxSize <= 0");
|
throw new IllegalArgumentException("maxSize <= 0");
|
||||||
}
|
}
|
||||||
this.maxSize = maxSize;
|
this.maxSize = maxSize;
|
||||||
this.map = new LinkedHashMap<String, Bitmap>(0, 0.75f, true);
|
this.map = new LinkedHashMap<String, BitmapDrawable>(0, 0.75f, true);
|
||||||
this.mapFilters = new LinkedHashMap<String, ArrayList<String>>();
|
this.mapFilters = new LinkedHashMap<String, ArrayList<String>>();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -54,12 +54,12 @@ public class LruCache {
|
|||||||
* head of the queue. This returns null if a value is not cached and cannot
|
* head of the queue. This returns null if a value is not cached and cannot
|
||||||
* be created.
|
* be created.
|
||||||
*/
|
*/
|
||||||
public final Bitmap get(String key) {
|
public final BitmapDrawable get(String key) {
|
||||||
if (key == null) {
|
if (key == null) {
|
||||||
throw new NullPointerException("key == null");
|
throw new NullPointerException("key == null");
|
||||||
}
|
}
|
||||||
|
|
||||||
Bitmap mapValue;
|
BitmapDrawable mapValue;
|
||||||
synchronized (this) {
|
synchronized (this) {
|
||||||
mapValue = map.get(key);
|
mapValue = map.get(key);
|
||||||
if (mapValue != null) {
|
if (mapValue != null) {
|
||||||
@ -85,12 +85,12 @@ public class LruCache {
|
|||||||
*
|
*
|
||||||
* @return the previous value mapped by {@code key}.
|
* @return the previous value mapped by {@code key}.
|
||||||
*/
|
*/
|
||||||
public Bitmap put(String key, Bitmap value) {
|
public BitmapDrawable put(String key, BitmapDrawable value) {
|
||||||
if (key == null || value == null) {
|
if (key == null || value == null) {
|
||||||
throw new NullPointerException("key == null || value == null");
|
throw new NullPointerException("key == null || value == null");
|
||||||
}
|
}
|
||||||
|
|
||||||
Bitmap previous;
|
BitmapDrawable previous;
|
||||||
synchronized (this) {
|
synchronized (this) {
|
||||||
putCount++;
|
putCount++;
|
||||||
size += safeSizeOf(key, value);
|
size += safeSizeOf(key, value);
|
||||||
@ -125,7 +125,7 @@ public class LruCache {
|
|||||||
private void trimToSize(int maxSize) {
|
private void trimToSize(int maxSize) {
|
||||||
while (true) {
|
while (true) {
|
||||||
String key;
|
String key;
|
||||||
Bitmap value;
|
BitmapDrawable value;
|
||||||
synchronized (this) {
|
synchronized (this) {
|
||||||
if (size < 0 || (map.isEmpty() && size != 0)) {
|
if (size < 0 || (map.isEmpty() && size != 0)) {
|
||||||
throw new IllegalStateException(getClass().getName()
|
throw new IllegalStateException(getClass().getName()
|
||||||
@ -136,7 +136,7 @@ public class LruCache {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
Map.Entry<String, Bitmap> toEvict = map.entrySet().iterator().next();
|
Map.Entry<String, BitmapDrawable> toEvict = map.entrySet().iterator().next();
|
||||||
key = toEvict.getKey();
|
key = toEvict.getKey();
|
||||||
value = toEvict.getValue();
|
value = toEvict.getValue();
|
||||||
map.remove(key);
|
map.remove(key);
|
||||||
@ -164,12 +164,12 @@ public class LruCache {
|
|||||||
*
|
*
|
||||||
* @return the previous value mapped by {@code key}.
|
* @return the previous value mapped by {@code key}.
|
||||||
*/
|
*/
|
||||||
public final Bitmap remove(String key) {
|
public final BitmapDrawable remove(String key) {
|
||||||
if (key == null) {
|
if (key == null) {
|
||||||
throw new NullPointerException("key == null");
|
throw new NullPointerException("key == null");
|
||||||
}
|
}
|
||||||
|
|
||||||
Bitmap previous;
|
BitmapDrawable previous;
|
||||||
synchronized (this) {
|
synchronized (this) {
|
||||||
previous = map.remove(key);
|
previous = map.remove(key);
|
||||||
if (previous != null) {
|
if (previous != null) {
|
||||||
@ -214,9 +214,9 @@ public class LruCache {
|
|||||||
* this removal was caused by a {@link #put}. Otherwise it was caused by
|
* this removal was caused by a {@link #put}. Otherwise it was caused by
|
||||||
* an eviction or a {@link #remove}.
|
* an eviction or a {@link #remove}.
|
||||||
*/
|
*/
|
||||||
protected void entryRemoved(boolean evicted, String key, Bitmap oldValue, Bitmap newValue) {}
|
protected void entryRemoved(boolean evicted, String key, BitmapDrawable oldValue, BitmapDrawable newValue) {}
|
||||||
|
|
||||||
private int safeSizeOf(String key, Bitmap value) {
|
private int safeSizeOf(String key, BitmapDrawable value) {
|
||||||
int result = sizeOf(key, value);
|
int result = sizeOf(key, value);
|
||||||
if (result < 0) {
|
if (result < 0) {
|
||||||
throw new IllegalStateException("Negative size: " + key + "=" + value);
|
throw new IllegalStateException("Negative size: " + key + "=" + value);
|
||||||
@ -231,7 +231,7 @@ public class LruCache {
|
|||||||
*
|
*
|
||||||
* <p>An entry's size must not change while it is in the cache.
|
* <p>An entry's size must not change while it is in the cache.
|
||||||
*/
|
*/
|
||||||
protected int sizeOf(String key, Bitmap value) {
|
protected int sizeOf(String key, BitmapDrawable value) {
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
@ -8,8 +8,13 @@
|
|||||||
|
|
||||||
package org.telegram.android;
|
package org.telegram.android;
|
||||||
|
|
||||||
|
import android.app.Activity;
|
||||||
import android.app.ProgressDialog;
|
import android.app.ProgressDialog;
|
||||||
|
import android.content.BroadcastReceiver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.content.IntentFilter;
|
||||||
|
import android.content.SharedPreferences;
|
||||||
import android.database.ContentObserver;
|
import android.database.ContentObserver;
|
||||||
import android.database.Cursor;
|
import android.database.Cursor;
|
||||||
import android.media.AudioFormat;
|
import android.media.AudioFormat;
|
||||||
@ -18,6 +23,7 @@ import android.media.AudioRecord;
|
|||||||
import android.media.AudioTrack;
|
import android.media.AudioTrack;
|
||||||
import android.media.MediaPlayer;
|
import android.media.MediaPlayer;
|
||||||
import android.media.MediaRecorder;
|
import android.media.MediaRecorder;
|
||||||
|
import android.net.ConnectivityManager;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.os.Environment;
|
import android.os.Environment;
|
||||||
import android.os.ParcelFileDescriptor;
|
import android.os.ParcelFileDescriptor;
|
||||||
@ -29,12 +35,10 @@ import org.telegram.messenger.ConnectionsManager;
|
|||||||
import org.telegram.messenger.DispatchQueue;
|
import org.telegram.messenger.DispatchQueue;
|
||||||
import org.telegram.messenger.FileLoader;
|
import org.telegram.messenger.FileLoader;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.objects.MessageObject;
|
|
||||||
import org.telegram.ui.ApplicationLoader;
|
import org.telegram.ui.ApplicationLoader;
|
||||||
import org.telegram.ui.Cells.ChatMediaCell;
|
import org.telegram.ui.Cells.ChatMediaCell;
|
||||||
import org.telegram.ui.Views.GifDrawable;
|
import org.telegram.ui.Views.GifDrawable;
|
||||||
@ -129,15 +133,19 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public final static int audioProgressDidChanged = 50001;
|
public static final int AUTODOWNLOAD_MASK_PHOTO = 1;
|
||||||
public final static int audioDidReset = 50002;
|
public static final int AUTODOWNLOAD_MASK_AUDIO = 2;
|
||||||
public final static int recordProgressChanged = 50003;
|
public static final int AUTODOWNLOAD_MASK_VIDEO = 4;
|
||||||
public final static int recordStarted = 50004;
|
public static final int AUTODOWNLOAD_MASK_DOCUMENT = 8;
|
||||||
public final static int recordStartError = 50005;
|
public int mobileDataDownloadMask = 0;
|
||||||
public final static int recordStopped = 50006;
|
public int wifiDownloadMask = 0;
|
||||||
public final static int screenshotTook = 50007;
|
public int roamingDownloadMask = 0;
|
||||||
public final static int albumsDidLoaded = 50008;
|
private int lastCheckMask = 0;
|
||||||
public final static int audioDidSent = 50009;
|
private ArrayList<DownloadObject> photoDownloadQueue = new ArrayList<DownloadObject>();
|
||||||
|
private ArrayList<DownloadObject> audioDownloadQueue = new ArrayList<DownloadObject>();
|
||||||
|
private ArrayList<DownloadObject> documentDownloadQueue = new ArrayList<DownloadObject>();
|
||||||
|
private ArrayList<DownloadObject> videoDownloadQueue = new ArrayList<DownloadObject>();
|
||||||
|
private HashMap<String, DownloadObject> downloadQueueKeys = new HashMap<String, DownloadObject>();
|
||||||
|
|
||||||
private HashMap<String, ArrayList<WeakReference<FileDownloadProgressListener>>> loadingFileObservers = new HashMap<String, ArrayList<WeakReference<FileDownloadProgressListener>>>();
|
private HashMap<String, ArrayList<WeakReference<FileDownloadProgressListener>>> loadingFileObservers = new HashMap<String, ArrayList<WeakReference<FileDownloadProgressListener>>>();
|
||||||
private HashMap<Integer, String> observersByTag = new HashMap<Integer, String>();
|
private HashMap<Integer, String> observersByTag = new HashMap<Integer, String>();
|
||||||
@ -233,10 +241,10 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
recordQueue.postRunnable(recordRunnable);
|
recordQueue.postRunnable(recordRunnable);
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
NotificationCenter.getInstance().postNotificationName(recordProgressChanged, System.currentTimeMillis() - recordStartTime);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.recordProgressChanged, System.currentTimeMillis() - recordStartTime);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
@ -355,11 +363,26 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
playerQueue = new DispatchQueue("playerQueue");
|
playerQueue = new DispatchQueue("playerQueue");
|
||||||
fileDecodingQueue = new DispatchQueue("fileDecodingQueue");
|
fileDecodingQueue = new DispatchQueue("fileDecodingQueue");
|
||||||
|
|
||||||
|
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("mainconfig", Activity.MODE_PRIVATE);
|
||||||
|
mobileDataDownloadMask = preferences.getInt("mobileDataDownloadMask", AUTODOWNLOAD_MASK_PHOTO | AUTODOWNLOAD_MASK_AUDIO);
|
||||||
|
wifiDownloadMask = preferences.getInt("wifiDownloadMask", AUTODOWNLOAD_MASK_PHOTO | AUTODOWNLOAD_MASK_AUDIO);
|
||||||
|
roamingDownloadMask = preferences.getInt("roamingDownloadMask", 0);
|
||||||
|
|
||||||
NotificationCenter.getInstance().addObserver(this, FileLoader.FileDidFailedLoad);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.FileDidFailedLoad);
|
||||||
NotificationCenter.getInstance().addObserver(this, FileLoader.FileDidLoaded);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.FileDidLoaded);
|
||||||
NotificationCenter.getInstance().addObserver(this, FileLoader.FileLoadProgressChanged);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.FileLoadProgressChanged);
|
||||||
NotificationCenter.getInstance().addObserver(this, FileLoader.FileUploadProgressChanged);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.FileUploadProgressChanged);
|
||||||
|
|
||||||
|
BroadcastReceiver networkStateReceiver = new BroadcastReceiver() {
|
||||||
|
@Override
|
||||||
|
public void onReceive(Context context, Intent intent) {
|
||||||
|
checkAutodownloadSettings();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
IntentFilter filter = new IntentFilter(ConnectivityManager.CONNECTIVITY_ACTION);
|
||||||
|
ApplicationLoader.applicationContext.registerReceiver(networkStateReceiver, filter);
|
||||||
|
|
||||||
|
checkAutodownloadSettings();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void startProgressTimer() {
|
private void startProgressTimer() {
|
||||||
@ -377,7 +400,7 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
synchronized (sync) {
|
synchronized (sync) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
if (playingMessageObject != null && (audioPlayer != null || audioTrackPlayer != null) && !isPaused) {
|
if (playingMessageObject != null && (audioPlayer != null || audioTrackPlayer != null) && !isPaused) {
|
||||||
@ -404,7 +427,7 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
lastProgress = progress;
|
lastProgress = progress;
|
||||||
playingMessageObject.audioProgress = value;
|
playingMessageObject.audioProgress = value;
|
||||||
playingMessageObject.audioProgressSec = lastProgress / 1000;
|
playingMessageObject.audioProgressSec = lastProgress / 1000;
|
||||||
NotificationCenter.getInstance().postNotificationName(audioProgressDidChanged, playingMessageObject.messageOwner.id, value);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.audioProgressDidChanged, playingMessageObject.messageOwner.id, value);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
@ -438,6 +461,186 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
}
|
}
|
||||||
currentMediaCell = null;
|
currentMediaCell = null;
|
||||||
currentGifMessageObject = null;
|
currentGifMessageObject = null;
|
||||||
|
photoDownloadQueue.clear();
|
||||||
|
audioDownloadQueue.clear();
|
||||||
|
documentDownloadQueue.clear();
|
||||||
|
videoDownloadQueue.clear();
|
||||||
|
downloadQueueKeys.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected int getAutodownloadMask() {
|
||||||
|
int mask = 0;
|
||||||
|
if ((mobileDataDownloadMask & AUTODOWNLOAD_MASK_PHOTO) != 0 || (wifiDownloadMask & AUTODOWNLOAD_MASK_PHOTO) != 0 || (roamingDownloadMask & AUTODOWNLOAD_MASK_PHOTO) != 0) {
|
||||||
|
mask |= AUTODOWNLOAD_MASK_PHOTO;
|
||||||
|
}
|
||||||
|
if ((mobileDataDownloadMask & AUTODOWNLOAD_MASK_AUDIO) != 0 || (wifiDownloadMask & AUTODOWNLOAD_MASK_AUDIO) != 0 || (roamingDownloadMask & AUTODOWNLOAD_MASK_AUDIO) != 0) {
|
||||||
|
mask |= AUTODOWNLOAD_MASK_AUDIO;
|
||||||
|
}
|
||||||
|
if ((mobileDataDownloadMask & AUTODOWNLOAD_MASK_VIDEO) != 0 || (wifiDownloadMask & AUTODOWNLOAD_MASK_VIDEO) != 0 || (roamingDownloadMask & AUTODOWNLOAD_MASK_VIDEO) != 0) {
|
||||||
|
mask |= AUTODOWNLOAD_MASK_VIDEO;
|
||||||
|
}
|
||||||
|
if ((mobileDataDownloadMask & AUTODOWNLOAD_MASK_DOCUMENT) != 0 || (wifiDownloadMask & AUTODOWNLOAD_MASK_DOCUMENT) != 0 || (roamingDownloadMask & AUTODOWNLOAD_MASK_DOCUMENT) != 0) {
|
||||||
|
mask |= AUTODOWNLOAD_MASK_DOCUMENT;
|
||||||
|
}
|
||||||
|
return mask;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void checkAutodownloadSettings() {
|
||||||
|
int currentMask = getCurrentDownloadMask();
|
||||||
|
if (currentMask == lastCheckMask) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
FileLog.e("tmessages", "check download mask = " + currentMask);
|
||||||
|
lastCheckMask = currentMask;
|
||||||
|
if ((currentMask & AUTODOWNLOAD_MASK_PHOTO) != 0) {
|
||||||
|
if (photoDownloadQueue.isEmpty()) {
|
||||||
|
newDownloadObjectsAvailable(AUTODOWNLOAD_MASK_PHOTO);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for (DownloadObject downloadObject : photoDownloadQueue) {
|
||||||
|
FileLoader.getInstance().cancelLoadFile((TLRPC.PhotoSize)downloadObject.object);
|
||||||
|
}
|
||||||
|
photoDownloadQueue.clear();
|
||||||
|
}
|
||||||
|
if ((currentMask & AUTODOWNLOAD_MASK_AUDIO) != 0) {
|
||||||
|
if (audioDownloadQueue.isEmpty()) {
|
||||||
|
newDownloadObjectsAvailable(AUTODOWNLOAD_MASK_AUDIO);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for (DownloadObject downloadObject : audioDownloadQueue) {
|
||||||
|
FileLoader.getInstance().cancelLoadFile((TLRPC.Audio)downloadObject.object);
|
||||||
|
}
|
||||||
|
audioDownloadQueue.clear();
|
||||||
|
}
|
||||||
|
if ((currentMask & AUTODOWNLOAD_MASK_DOCUMENT) != 0) {
|
||||||
|
if (documentDownloadQueue.isEmpty()) {
|
||||||
|
newDownloadObjectsAvailable(AUTODOWNLOAD_MASK_DOCUMENT);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for (DownloadObject downloadObject : documentDownloadQueue) {
|
||||||
|
FileLoader.getInstance().cancelLoadFile((TLRPC.Document)downloadObject.object);
|
||||||
|
}
|
||||||
|
documentDownloadQueue.clear();
|
||||||
|
}
|
||||||
|
if ((currentMask & AUTODOWNLOAD_MASK_VIDEO) != 0) {
|
||||||
|
if (videoDownloadQueue.isEmpty()) {
|
||||||
|
newDownloadObjectsAvailable(AUTODOWNLOAD_MASK_VIDEO);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for (DownloadObject downloadObject : videoDownloadQueue) {
|
||||||
|
FileLoader.getInstance().cancelLoadFile((TLRPC.Video)downloadObject.object);
|
||||||
|
}
|
||||||
|
videoDownloadQueue.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
int mask = getAutodownloadMask();
|
||||||
|
if (mask == 0) {
|
||||||
|
MessagesStorage.getInstance().clearDownloadQueue(0);
|
||||||
|
} else {
|
||||||
|
if ((mask & AUTODOWNLOAD_MASK_PHOTO) == 0) {
|
||||||
|
MessagesStorage.getInstance().clearDownloadQueue(AUTODOWNLOAD_MASK_PHOTO);
|
||||||
|
}
|
||||||
|
if ((mask & AUTODOWNLOAD_MASK_AUDIO) == 0) {
|
||||||
|
MessagesStorage.getInstance().clearDownloadQueue(AUTODOWNLOAD_MASK_AUDIO);
|
||||||
|
}
|
||||||
|
if ((mask & AUTODOWNLOAD_MASK_VIDEO) == 0) {
|
||||||
|
MessagesStorage.getInstance().clearDownloadQueue(AUTODOWNLOAD_MASK_VIDEO);
|
||||||
|
}
|
||||||
|
if ((mask & AUTODOWNLOAD_MASK_DOCUMENT) == 0) {
|
||||||
|
MessagesStorage.getInstance().clearDownloadQueue(AUTODOWNLOAD_MASK_DOCUMENT);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean canDownloadMedia(int type) {
|
||||||
|
return (getCurrentDownloadMask() & type) != 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
private int getCurrentDownloadMask() {
|
||||||
|
if (ConnectionsManager.isConnectedToWiFi()) {
|
||||||
|
return wifiDownloadMask;
|
||||||
|
} else if(ConnectionsManager.isRoaming()) {
|
||||||
|
return roamingDownloadMask;
|
||||||
|
} else {
|
||||||
|
return mobileDataDownloadMask;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void processDownloadObjects(int type, ArrayList<DownloadObject> objects) {
|
||||||
|
if (objects.isEmpty()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
ArrayList<DownloadObject> queue = null;
|
||||||
|
if (type == AUTODOWNLOAD_MASK_PHOTO) {
|
||||||
|
queue = photoDownloadQueue;
|
||||||
|
} else if (type == AUTODOWNLOAD_MASK_AUDIO) {
|
||||||
|
queue = audioDownloadQueue;
|
||||||
|
} else if (type == AUTODOWNLOAD_MASK_VIDEO) {
|
||||||
|
queue = videoDownloadQueue;
|
||||||
|
} else if (type == AUTODOWNLOAD_MASK_DOCUMENT) {
|
||||||
|
queue = documentDownloadQueue;
|
||||||
|
}
|
||||||
|
queue.addAll(objects);
|
||||||
|
for (DownloadObject downloadObject : queue) {
|
||||||
|
String path = FileLoader.getAttachFileName(downloadObject.object);
|
||||||
|
downloadQueueKeys.put(path, downloadObject);
|
||||||
|
if (downloadObject.object instanceof TLRPC.Audio) {
|
||||||
|
FileLoader.getInstance().loadFile((TLRPC.Audio)downloadObject.object, false);
|
||||||
|
} else if (downloadObject.object instanceof TLRPC.PhotoSize) {
|
||||||
|
FileLoader.getInstance().loadFile((TLRPC.PhotoSize)downloadObject.object);
|
||||||
|
} else if (downloadObject.object instanceof TLRPC.Video) {
|
||||||
|
FileLoader.getInstance().loadFile((TLRPC.Video)downloadObject.object);
|
||||||
|
} else if (downloadObject.object instanceof TLRPC.Document) {
|
||||||
|
FileLoader.getInstance().loadFile((TLRPC.Document)downloadObject.object);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void newDownloadObjectsAvailable(int downloadMask) {
|
||||||
|
int mask = getCurrentDownloadMask();
|
||||||
|
if ((mask & AUTODOWNLOAD_MASK_PHOTO) != 0 && (downloadMask & AUTODOWNLOAD_MASK_PHOTO) != 0 && photoDownloadQueue.isEmpty()) {
|
||||||
|
MessagesStorage.getInstance().getDownloadQueue(AUTODOWNLOAD_MASK_PHOTO);
|
||||||
|
}
|
||||||
|
if ((mask & AUTODOWNLOAD_MASK_AUDIO) != 0 && (downloadMask & AUTODOWNLOAD_MASK_AUDIO) != 0 && audioDownloadQueue.isEmpty()) {
|
||||||
|
MessagesStorage.getInstance().getDownloadQueue(AUTODOWNLOAD_MASK_AUDIO);
|
||||||
|
}
|
||||||
|
if ((mask & AUTODOWNLOAD_MASK_VIDEO) != 0 && (downloadMask & AUTODOWNLOAD_MASK_VIDEO) != 0 && videoDownloadQueue.isEmpty()) {
|
||||||
|
MessagesStorage.getInstance().getDownloadQueue(AUTODOWNLOAD_MASK_VIDEO);
|
||||||
|
}
|
||||||
|
if ((mask & AUTODOWNLOAD_MASK_DOCUMENT) != 0 && (downloadMask & AUTODOWNLOAD_MASK_DOCUMENT) != 0 && documentDownloadQueue.isEmpty()) {
|
||||||
|
MessagesStorage.getInstance().getDownloadQueue(AUTODOWNLOAD_MASK_DOCUMENT);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkDownloadFinished(String fileName, boolean canceled) {
|
||||||
|
DownloadObject downloadObject = downloadQueueKeys.get(fileName);
|
||||||
|
if (downloadObject != null) {
|
||||||
|
downloadQueueKeys.remove(fileName);
|
||||||
|
if (!canceled) {
|
||||||
|
MessagesStorage.getInstance().removeFromDownloadQueue(downloadObject.id, downloadObject.type);
|
||||||
|
}
|
||||||
|
if (downloadObject.type == AUTODOWNLOAD_MASK_PHOTO) {
|
||||||
|
photoDownloadQueue.remove(downloadObject);
|
||||||
|
if (photoDownloadQueue.isEmpty()) {
|
||||||
|
newDownloadObjectsAvailable(AUTODOWNLOAD_MASK_PHOTO);
|
||||||
|
}
|
||||||
|
} else if (downloadObject.type == AUTODOWNLOAD_MASK_AUDIO) {
|
||||||
|
audioDownloadQueue.remove(downloadObject);
|
||||||
|
if (audioDownloadQueue.isEmpty()) {
|
||||||
|
newDownloadObjectsAvailable(AUTODOWNLOAD_MASK_AUDIO);
|
||||||
|
}
|
||||||
|
} else if (downloadObject.type == AUTODOWNLOAD_MASK_VIDEO) {
|
||||||
|
videoDownloadQueue.remove(downloadObject);
|
||||||
|
if (videoDownloadQueue.isEmpty()) {
|
||||||
|
newDownloadObjectsAvailable(AUTODOWNLOAD_MASK_VIDEO);
|
||||||
|
}
|
||||||
|
} else if (downloadObject.type == AUTODOWNLOAD_MASK_DOCUMENT) {
|
||||||
|
documentDownloadQueue.remove(downloadObject);
|
||||||
|
if (documentDownloadQueue.isEmpty()) {
|
||||||
|
newDownloadObjectsAvailable(AUTODOWNLOAD_MASK_DOCUMENT);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void startMediaObserver() {
|
public void startMediaObserver() {
|
||||||
@ -556,10 +759,10 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
cursor.close();
|
cursor.close();
|
||||||
}
|
}
|
||||||
if (!screenshotDates.isEmpty()) {
|
if (!screenshotDates.isEmpty()) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
NotificationCenter.getInstance().postNotificationName(screenshotTook);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.screenshotTook);
|
||||||
checkScreenshots(screenshotDates);
|
checkScreenshots(screenshotDates);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -588,7 +791,7 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (send) {
|
if (send) {
|
||||||
MessagesController.getInstance().sendScreenshotMessage(lastSecretChat, lastSecretChatVisibleMessages);
|
SendMessagesHelper.getInstance().sendScreenshotMessage(lastSecretChat, lastSecretChatVisibleMessages);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -657,7 +860,7 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, Object... args) {
|
public void didReceivedNotification(int id, Object... args) {
|
||||||
if (id == FileLoader.FileDidFailedLoad) {
|
if (id == NotificationCenter.FileDidFailedLoad) {
|
||||||
listenerInProgress = true;
|
listenerInProgress = true;
|
||||||
String fileName = (String)args[0];
|
String fileName = (String)args[0];
|
||||||
ArrayList<WeakReference<FileDownloadProgressListener>> arrayList = loadingFileObservers.get(fileName);
|
ArrayList<WeakReference<FileDownloadProgressListener>> arrayList = loadingFileObservers.get(fileName);
|
||||||
@ -672,7 +875,8 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
}
|
}
|
||||||
listenerInProgress = false;
|
listenerInProgress = false;
|
||||||
processLaterArrays();
|
processLaterArrays();
|
||||||
} else if (id == FileLoader.FileDidLoaded) {
|
checkDownloadFinished(fileName, (Boolean)args[1]);
|
||||||
|
} else if (id == NotificationCenter.FileDidLoaded) {
|
||||||
listenerInProgress = true;
|
listenerInProgress = true;
|
||||||
String fileName = (String)args[0];
|
String fileName = (String)args[0];
|
||||||
ArrayList<WeakReference<FileDownloadProgressListener>> arrayList = loadingFileObservers.get(fileName);
|
ArrayList<WeakReference<FileDownloadProgressListener>> arrayList = loadingFileObservers.get(fileName);
|
||||||
@ -687,7 +891,8 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
}
|
}
|
||||||
listenerInProgress = false;
|
listenerInProgress = false;
|
||||||
processLaterArrays();
|
processLaterArrays();
|
||||||
} else if (id == FileLoader.FileLoadProgressChanged) {
|
checkDownloadFinished(fileName, false);
|
||||||
|
} else if (id == NotificationCenter.FileLoadProgressChanged) {
|
||||||
listenerInProgress = true;
|
listenerInProgress = true;
|
||||||
String fileName = (String)args[0];
|
String fileName = (String)args[0];
|
||||||
ArrayList<WeakReference<FileDownloadProgressListener>> arrayList = loadingFileObservers.get(fileName);
|
ArrayList<WeakReference<FileDownloadProgressListener>> arrayList = loadingFileObservers.get(fileName);
|
||||||
@ -701,7 +906,7 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
}
|
}
|
||||||
listenerInProgress = false;
|
listenerInProgress = false;
|
||||||
processLaterArrays();
|
processLaterArrays();
|
||||||
} else if (id == FileLoader.FileUploadProgressChanged) {
|
} else if (id == NotificationCenter.FileUploadProgressChanged) {
|
||||||
String location = (String)args[0];
|
String location = (String)args[0];
|
||||||
listenerInProgress = true;
|
listenerInProgress = true;
|
||||||
String fileName = (String)args[0];
|
String fileName = (String)args[0];
|
||||||
@ -800,7 +1005,7 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
if (count > 0) {
|
if (count > 0) {
|
||||||
final long pcm = buffer.pcmOffset;
|
final long pcm = buffer.pcmOffset;
|
||||||
final int marker = buffer.finished == 1 ? buffer.size : -1;
|
final int marker = buffer.finished == 1 ? buffer.size : -1;
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
lastPlayPcm = pcm;
|
lastPlayPcm = pcm;
|
||||||
@ -868,7 +1073,7 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
playingMessageObject.audioProgressSec = 0;
|
playingMessageObject.audioProgressSec = 0;
|
||||||
playingMessageObject = null;
|
playingMessageObject = null;
|
||||||
if (notify) {
|
if (notify) {
|
||||||
NotificationCenter.getInstance().postNotificationName(audioDidReset, lastFile.messageOwner.id);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.audioDidReset, lastFile.messageOwner.id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -889,7 +1094,7 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
freePlayerBuffers.addAll(usedPlayerBuffers);
|
freePlayerBuffers.addAll(usedPlayerBuffers);
|
||||||
usedPlayerBuffers.clear();
|
usedPlayerBuffers.clear();
|
||||||
}
|
}
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
if (!isPaused) {
|
if (!isPaused) {
|
||||||
@ -1142,10 +1347,10 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
if (audioRecorder != null) {
|
if (audioRecorder != null) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
NotificationCenter.getInstance().postNotificationName(recordStartError);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.recordStartError);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
return;
|
return;
|
||||||
@ -1159,14 +1364,14 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
UserConfig.lastLocalId--;
|
UserConfig.lastLocalId--;
|
||||||
UserConfig.saveConfig(false);
|
UserConfig.saveConfig(false);
|
||||||
|
|
||||||
recordingAudioFile = new File(AndroidUtilities.getCacheDir(), MessageObject.getAttachFileName(recordingAudio));
|
recordingAudioFile = new File(AndroidUtilities.getCacheDir(), FileLoader.getAttachFileName(recordingAudio));
|
||||||
|
|
||||||
try {
|
try {
|
||||||
if (startRecord(recordingAudioFile.getAbsolutePath()) == 0) {
|
if (startRecord(recordingAudioFile.getAbsolutePath()) == 0) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
NotificationCenter.getInstance().postNotificationName(recordStartError);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.recordStartError);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
return;
|
return;
|
||||||
@ -1191,20 +1396,20 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
FileLog.e("tmessages", e2);
|
FileLog.e("tmessages", e2);
|
||||||
}
|
}
|
||||||
|
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
NotificationCenter.getInstance().postNotificationName(recordStartError);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.recordStartError);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
recordQueue.postRunnable(recordRunnable);
|
recordQueue.postRunnable(recordRunnable);
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
NotificationCenter.getInstance().postNotificationName(recordStarted);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.recordStarted);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -1219,7 +1424,7 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
stopRecord();
|
stopRecord();
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
audioToSend.date = ConnectionsManager.getInstance().getCurrentTime();
|
audioToSend.date = ConnectionsManager.getInstance().getCurrentTime();
|
||||||
@ -1228,11 +1433,11 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
long duration = recordTimeCount;
|
long duration = recordTimeCount;
|
||||||
audioToSend.duration = (int) (duration / 1000);
|
audioToSend.duration = (int) (duration / 1000);
|
||||||
if (duration > 700) {
|
if (duration > 700) {
|
||||||
MessagesController.getInstance().sendMessage(audioToSend, recordDialogId);
|
SendMessagesHelper.getInstance().sendMessage(audioToSend, recordDialogId);
|
||||||
} else {
|
} else {
|
||||||
recordingAudioFileToSend.delete();
|
recordingAudioFileToSend.delete();
|
||||||
}
|
}
|
||||||
NotificationCenter.getInstance().postNotificationName(audioDidSent);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.audioDidSent);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -1275,10 +1480,10 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
NotificationCenter.getInstance().postNotificationName(recordStopped);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.recordStopped);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -1347,7 +1552,7 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
if (lastProgress <= System.currentTimeMillis() - 500) {
|
if (lastProgress <= System.currentTimeMillis() - 500) {
|
||||||
lastProgress = System.currentTimeMillis();
|
lastProgress = System.currentTimeMillis();
|
||||||
final int progress = (int) ((float) a / (float) size * 100);
|
final int progress = (int) ((float) a / (float) size * 100);
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
try {
|
try {
|
||||||
@ -1379,7 +1584,7 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
if (finalProgress != null) {
|
if (finalProgress != null) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
try {
|
try {
|
||||||
@ -1612,10 +1817,10 @@ public class MediaController implements NotificationCenter.NotificationCenterDel
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
final Integer cameraAlbumIdFinal = cameraAlbumId;
|
final Integer cameraAlbumIdFinal = cameraAlbumId;
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
NotificationCenter.getInstance().postNotificationName(albumsDidLoaded, guid, albumsSorted, cameraAlbumIdFinal);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.albumsDidLoaded, guid, albumsSorted, cameraAlbumIdFinal);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
* Copyright Nikolai Kudashov, 2013.
|
* Copyright Nikolai Kudashov, 2013.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.telegram.objects;
|
package org.telegram.android;
|
||||||
|
|
||||||
import android.graphics.Bitmap;
|
import android.graphics.Bitmap;
|
||||||
import android.graphics.Paint;
|
import android.graphics.Paint;
|
||||||
@ -16,13 +16,9 @@ import android.text.StaticLayout;
|
|||||||
import android.text.TextPaint;
|
import android.text.TextPaint;
|
||||||
import android.text.util.Linkify;
|
import android.text.util.Linkify;
|
||||||
|
|
||||||
import org.telegram.android.AndroidUtilities;
|
import org.telegram.messenger.FileLoader;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.android.LocaleController;
|
|
||||||
import org.telegram.messenger.TLObject;
|
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.android.Emoji;
|
|
||||||
import org.telegram.android.MessagesController;
|
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
@ -33,6 +29,11 @@ import java.util.Calendar;
|
|||||||
import java.util.GregorianCalendar;
|
import java.util.GregorianCalendar;
|
||||||
|
|
||||||
public class MessageObject {
|
public class MessageObject {
|
||||||
|
|
||||||
|
public static final int MESSAGE_SEND_STATE_SENDING = 1;
|
||||||
|
public static final int MESSAGE_SEND_STATE_SENT = 0;
|
||||||
|
public static final int MESSAGE_SEND_STATE_SEND_ERROR = 2;
|
||||||
|
|
||||||
public TLRPC.Message messageOwner;
|
public TLRPC.Message messageOwner;
|
||||||
public CharSequence messageText;
|
public CharSequence messageText;
|
||||||
public int type;
|
public int type;
|
||||||
@ -78,9 +79,12 @@ public class MessageObject {
|
|||||||
|
|
||||||
if (message instanceof TLRPC.TL_messageService) {
|
if (message instanceof TLRPC.TL_messageService) {
|
||||||
if (message.action != null) {
|
if (message.action != null) {
|
||||||
TLRPC.User fromUser = users.get(message.from_id);
|
TLRPC.User fromUser = null;
|
||||||
|
if (users != null) {
|
||||||
|
fromUser = users.get(message.from_id);
|
||||||
|
}
|
||||||
if (fromUser == null) {
|
if (fromUser == null) {
|
||||||
fromUser = MessagesController.getInstance().users.get(message.from_id);
|
fromUser = MessagesController.getInstance().getUser(message.from_id);
|
||||||
}
|
}
|
||||||
if (message.action instanceof TLRPC.TL_messageActionChatCreate) {
|
if (message.action instanceof TLRPC.TL_messageActionChatCreate) {
|
||||||
if (isFromMe()) {
|
if (isFromMe()) {
|
||||||
@ -104,9 +108,12 @@ public class MessageObject {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
TLRPC.User who = users.get(message.action.user_id);
|
TLRPC.User who = null;
|
||||||
|
if (users != null) {
|
||||||
|
who = users.get(message.action.user_id);
|
||||||
|
}
|
||||||
if (who == null) {
|
if (who == null) {
|
||||||
MessagesController.getInstance().users.get(message.action.user_id);
|
who = MessagesController.getInstance().getUser(message.action.user_id);
|
||||||
}
|
}
|
||||||
if (who != null && fromUser != null) {
|
if (who != null && fromUser != null) {
|
||||||
if (isFromMe()) {
|
if (isFromMe()) {
|
||||||
@ -121,9 +128,12 @@ public class MessageObject {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (message.action instanceof TLRPC.TL_messageActionChatAddUser) {
|
} else if (message.action instanceof TLRPC.TL_messageActionChatAddUser) {
|
||||||
TLRPC.User whoUser = users.get(message.action.user_id);
|
TLRPC.User whoUser = null;
|
||||||
|
if (users != null) {
|
||||||
|
whoUser = users.get(message.action.user_id);
|
||||||
|
}
|
||||||
if (whoUser == null) {
|
if (whoUser == null) {
|
||||||
MessagesController.getInstance().users.get(message.action.user_id);
|
whoUser = MessagesController.getInstance().getUser(message.action.user_id);
|
||||||
}
|
}
|
||||||
if (whoUser != null && fromUser != null) {
|
if (whoUser != null && fromUser != null) {
|
||||||
if (isFromMe()) {
|
if (isFromMe()) {
|
||||||
@ -389,54 +399,23 @@ public class MessageObject {
|
|||||||
|
|
||||||
public String getFileName() {
|
public String getFileName() {
|
||||||
if (messageOwner.media instanceof TLRPC.TL_messageMediaVideo) {
|
if (messageOwner.media instanceof TLRPC.TL_messageMediaVideo) {
|
||||||
return getAttachFileName(messageOwner.media.video);
|
return FileLoader.getAttachFileName(messageOwner.media.video);
|
||||||
} else if (messageOwner.media instanceof TLRPC.TL_messageMediaDocument) {
|
} else if (messageOwner.media instanceof TLRPC.TL_messageMediaDocument) {
|
||||||
return getAttachFileName(messageOwner.media.document);
|
return FileLoader.getAttachFileName(messageOwner.media.document);
|
||||||
} else if (messageOwner.media instanceof TLRPC.TL_messageMediaAudio) {
|
} else if (messageOwner.media instanceof TLRPC.TL_messageMediaAudio) {
|
||||||
return getAttachFileName(messageOwner.media.audio);
|
return FileLoader.getAttachFileName(messageOwner.media.audio);
|
||||||
} else if (messageOwner.media instanceof TLRPC.TL_messageMediaPhoto) {
|
} else if (messageOwner.media instanceof TLRPC.TL_messageMediaPhoto) {
|
||||||
ArrayList<TLRPC.PhotoSize> sizes = messageOwner.media.photo.sizes;
|
ArrayList<TLRPC.PhotoSize> sizes = messageOwner.media.photo.sizes;
|
||||||
if (sizes.size() > 0) {
|
if (sizes.size() > 0) {
|
||||||
TLRPC.PhotoSize sizeFull = PhotoObject.getClosestPhotoSizeWithSize(sizes, 800, 800);
|
TLRPC.PhotoSize sizeFull = PhotoObject.getClosestPhotoSizeWithSize(sizes, 800, 800);
|
||||||
if (sizeFull != null) {
|
if (sizeFull != null) {
|
||||||
return getAttachFileName(sizeFull);
|
return FileLoader.getAttachFileName(sizeFull);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String getAttachFileName(TLObject attach) {
|
|
||||||
if (attach instanceof TLRPC.Video) {
|
|
||||||
TLRPC.Video video = (TLRPC.Video)attach;
|
|
||||||
return video.dc_id + "_" + video.id + ".mp4";
|
|
||||||
} else if (attach instanceof TLRPC.Document) {
|
|
||||||
TLRPC.Document document = (TLRPC.Document)attach;
|
|
||||||
String ext = document.file_name;
|
|
||||||
int idx = -1;
|
|
||||||
if (ext == null || (idx = ext.lastIndexOf(".")) == -1) {
|
|
||||||
ext = "";
|
|
||||||
} else {
|
|
||||||
ext = ext.substring(idx);
|
|
||||||
}
|
|
||||||
if (ext.length() > 1) {
|
|
||||||
return document.dc_id + "_" + document.id + ext;
|
|
||||||
} else {
|
|
||||||
return document.dc_id + "_" + document.id;
|
|
||||||
}
|
|
||||||
} else if (attach instanceof TLRPC.PhotoSize) {
|
|
||||||
TLRPC.PhotoSize photo = (TLRPC.PhotoSize)attach;
|
|
||||||
if (photo.location == null) {
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
return photo.location.volume_id + "_" + photo.location.local_id + ".jpg";
|
|
||||||
} else if (attach instanceof TLRPC.Audio) {
|
|
||||||
TLRPC.Audio audio = (TLRPC.Audio)attach;
|
|
||||||
return audio.dc_id + "_" + audio.id + ".m4a";
|
|
||||||
}
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
|
|
||||||
private void generateLayout() {
|
private void generateLayout() {
|
||||||
if (type != 0 && type != 1 && type != 8 && type != 9 || messageOwner.to_id == null || messageText == null || messageText.length() == 0) {
|
if (type != 0 && type != 1 && type != 8 && type != 9 || messageOwner.to_id == null || messageText == null || messageText.length() == 0) {
|
||||||
return;
|
return;
|
File diff suppressed because it is too large
Load Diff
@ -8,6 +8,8 @@
|
|||||||
|
|
||||||
package org.telegram.android;
|
package org.telegram.android;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.SharedPreferences;
|
||||||
import android.text.Html;
|
import android.text.Html;
|
||||||
import android.util.SparseArray;
|
import android.util.SparseArray;
|
||||||
|
|
||||||
@ -20,19 +22,18 @@ import org.telegram.messenger.ByteBufferDesc;
|
|||||||
import org.telegram.messenger.ConnectionsManager;
|
import org.telegram.messenger.ConnectionsManager;
|
||||||
import org.telegram.messenger.DispatchQueue;
|
import org.telegram.messenger.DispatchQueue;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
|
||||||
import org.telegram.messenger.TLClassStore;
|
import org.telegram.messenger.TLClassStore;
|
||||||
import org.telegram.messenger.TLObject;
|
import org.telegram.messenger.TLObject;
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.objects.MessageObject;
|
|
||||||
import org.telegram.ui.ApplicationLoader;
|
import org.telegram.ui.ApplicationLoader;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.concurrent.Semaphore;
|
import java.util.concurrent.Semaphore;
|
||||||
|
|
||||||
public class MessagesStorage {
|
public class MessagesStorage {
|
||||||
@ -53,8 +54,6 @@ public class MessagesStorage {
|
|||||||
private int lastSavedDate = 0;
|
private int lastSavedDate = 0;
|
||||||
private int lastSavedQts = 0;
|
private int lastSavedQts = 0;
|
||||||
|
|
||||||
public static final int wallpapersDidLoaded = 171;
|
|
||||||
|
|
||||||
private static volatile MessagesStorage Instance = null;
|
private static volatile MessagesStorage Instance = null;
|
||||||
public static MessagesStorage getInstance() {
|
public static MessagesStorage getInstance() {
|
||||||
MessagesStorage localInstance = Instance;
|
MessagesStorage localInstance = Instance;
|
||||||
@ -91,7 +90,7 @@ public class MessagesStorage {
|
|||||||
database.executeFast("CREATE TABLE messages(mid INTEGER PRIMARY KEY, uid INTEGER, read_state INTEGER, send_state INTEGER, date INTEGER, data BLOB, out INTEGER, ttl INTEGER)").stepThis().dispose();
|
database.executeFast("CREATE TABLE messages(mid INTEGER PRIMARY KEY, uid INTEGER, read_state INTEGER, send_state INTEGER, date INTEGER, data BLOB, out INTEGER, ttl INTEGER)").stepThis().dispose();
|
||||||
database.executeFast("CREATE TABLE chats(uid INTEGER PRIMARY KEY, name TEXT, data BLOB)").stepThis().dispose();
|
database.executeFast("CREATE TABLE chats(uid INTEGER PRIMARY KEY, name TEXT, data BLOB)").stepThis().dispose();
|
||||||
database.executeFast("CREATE TABLE enc_chats(uid INTEGER PRIMARY KEY, user INTEGER, name TEXT, data BLOB, g BLOB, authkey BLOB, ttl INTEGER)").stepThis().dispose();
|
database.executeFast("CREATE TABLE enc_chats(uid INTEGER PRIMARY KEY, user INTEGER, name TEXT, data BLOB, g BLOB, authkey BLOB, ttl INTEGER)").stepThis().dispose();
|
||||||
database.executeFast("CREATE TABLE dialogs(did INTEGER PRIMARY KEY, date INTEGER, unread_count INTEGER, last_mid INTEGER)").stepThis().dispose();
|
database.executeFast("CREATE TABLE dialogs(did INTEGER PRIMARY KEY, date INTEGER, unread_count INTEGER, last_mid INTEGER, flags INTEGER)").stepThis().dispose();
|
||||||
database.executeFast("CREATE TABLE chat_settings(uid INTEGER PRIMARY KEY, participants BLOB)").stepThis().dispose();
|
database.executeFast("CREATE TABLE chat_settings(uid INTEGER PRIMARY KEY, participants BLOB)").stepThis().dispose();
|
||||||
database.executeFast("CREATE TABLE contacts(uid INTEGER PRIMARY KEY, mutual INTEGER)").stepThis().dispose();
|
database.executeFast("CREATE TABLE contacts(uid INTEGER PRIMARY KEY, mutual INTEGER)").stepThis().dispose();
|
||||||
database.executeFast("CREATE TABLE pending_read(uid INTEGER PRIMARY KEY, max_id INTEGER)").stepThis().dispose();
|
database.executeFast("CREATE TABLE pending_read(uid INTEGER PRIMARY KEY, max_id INTEGER)").stepThis().dispose();
|
||||||
@ -103,12 +102,17 @@ public class MessagesStorage {
|
|||||||
database.executeFast("CREATE TABLE params(id INTEGER PRIMARY KEY, seq INTEGER, pts INTEGER, date INTEGER, qts INTEGER, lsv INTEGER, sg INTEGER, pbytes BLOB)").stepThis().dispose();
|
database.executeFast("CREATE TABLE params(id INTEGER PRIMARY KEY, seq INTEGER, pts INTEGER, date INTEGER, qts INTEGER, lsv INTEGER, sg INTEGER, pbytes BLOB)").stepThis().dispose();
|
||||||
database.executeFast("INSERT INTO params VALUES(1, 0, 0, 0, 0, 0, 0, NULL)").stepThis().dispose();
|
database.executeFast("INSERT INTO params VALUES(1, 0, 0, 0, 0, 0, 0, NULL)").stepThis().dispose();
|
||||||
database.executeFast("CREATE TABLE user_photos(uid INTEGER, id INTEGER, data BLOB, PRIMARY KEY (uid, id))").stepThis().dispose();
|
database.executeFast("CREATE TABLE user_photos(uid INTEGER, id INTEGER, data BLOB, PRIMARY KEY (uid, id))").stepThis().dispose();
|
||||||
|
database.executeFast("CREATE TABLE blocked_users(uid INTEGER PRIMARY KEY)").stepThis().dispose();
|
||||||
|
database.executeFast("CREATE TABLE download_queue(uid INTEGER, type INTEGER, date INTEGER, data BLOB, PRIMARY KEY (uid, type));").stepThis().dispose();
|
||||||
|
//database.executeFast("CREATE TABLE attach_data(uid INTEGER, id INTEGER, data BLOB, PRIMARY KEY (uid, id))").stepThis().dispose();
|
||||||
|
|
||||||
database.executeFast("CREATE TABLE user_contacts_v6(uid INTEGER PRIMARY KEY, fname TEXT, sname TEXT)").stepThis().dispose();
|
database.executeFast("CREATE TABLE user_contacts_v6(uid INTEGER PRIMARY KEY, fname TEXT, sname TEXT)").stepThis().dispose();
|
||||||
database.executeFast("CREATE TABLE user_phones_v6(uid INTEGER, phone TEXT, sphone TEXT, deleted INTEGER, PRIMARY KEY (uid, phone))").stepThis().dispose();
|
database.executeFast("CREATE TABLE user_phones_v6(uid INTEGER, phone TEXT, sphone TEXT, deleted INTEGER, PRIMARY KEY (uid, phone))").stepThis().dispose();
|
||||||
|
|
||||||
database.executeFast("CREATE TABLE sent_files_v2(uid TEXT, type INTEGER, data BLOB, PRIMARY KEY (uid, type))").stepThis().dispose();
|
database.executeFast("CREATE TABLE sent_files_v2(uid TEXT, type INTEGER, data BLOB, PRIMARY KEY (uid, type))").stepThis().dispose();
|
||||||
|
|
||||||
|
database.executeFast("CREATE INDEX IF NOT EXISTS type_date_idx_download_queue ON download_queue(type, date);").stepThis().dispose();
|
||||||
|
|
||||||
database.executeFast("CREATE INDEX IF NOT EXISTS mid_idx_randoms ON randoms(mid);").stepThis().dispose();
|
database.executeFast("CREATE INDEX IF NOT EXISTS mid_idx_randoms ON randoms(mid);").stepThis().dispose();
|
||||||
|
|
||||||
database.executeFast("CREATE INDEX IF NOT EXISTS sphone_deleted_idx_user_phones ON user_phones_v6(sphone, deleted);").stepThis().dispose();
|
database.executeFast("CREATE INDEX IF NOT EXISTS sphone_deleted_idx_user_phones ON user_phones_v6(sphone, deleted);").stepThis().dispose();
|
||||||
@ -116,7 +120,7 @@ public class MessagesStorage {
|
|||||||
database.executeFast("CREATE INDEX IF NOT EXISTS date_idx_dialogs ON dialogs(date);").stepThis().dispose();
|
database.executeFast("CREATE INDEX IF NOT EXISTS date_idx_dialogs ON dialogs(date);").stepThis().dispose();
|
||||||
database.executeFast("CREATE INDEX IF NOT EXISTS date_idx_enc_tasks ON enc_tasks(date);").stepThis().dispose();
|
database.executeFast("CREATE INDEX IF NOT EXISTS date_idx_enc_tasks ON enc_tasks(date);").stepThis().dispose();
|
||||||
database.executeFast("CREATE INDEX IF NOT EXISTS last_mid_idx_dialogs ON dialogs(last_mid);").stepThis().dispose();
|
database.executeFast("CREATE INDEX IF NOT EXISTS last_mid_idx_dialogs ON dialogs(last_mid);").stepThis().dispose();
|
||||||
database.executeFast("CREATE INDEX IF NOT EXISTS unread_count_idx_dialogs ON dialogs(unread_count);").stepThis().dispose();
|
database.executeFast("CREATE INDEX IF NOT EXISTS unread_count_flags_idx_dialogs ON dialogs(unread_count, flags);").stepThis().dispose();
|
||||||
|
|
||||||
database.executeFast("CREATE INDEX IF NOT EXISTS uid_mid_idx_media ON media(uid, mid);").stepThis().dispose();
|
database.executeFast("CREATE INDEX IF NOT EXISTS uid_mid_idx_media ON media(uid, mid);").stepThis().dispose();
|
||||||
database.executeFast("CREATE INDEX IF NOT EXISTS mid_idx_media ON media(mid);").stepThis().dispose();
|
database.executeFast("CREATE INDEX IF NOT EXISTS mid_idx_media ON media(mid);").stepThis().dispose();
|
||||||
@ -126,7 +130,11 @@ public class MessagesStorage {
|
|||||||
database.executeFast("CREATE INDEX IF NOT EXISTS uid_date_mid_idx_messages ON messages(uid, date, mid);").stepThis().dispose();
|
database.executeFast("CREATE INDEX IF NOT EXISTS uid_date_mid_idx_messages ON messages(uid, date, mid);").stepThis().dispose();
|
||||||
database.executeFast("CREATE INDEX IF NOT EXISTS mid_out_idx_messages ON messages(mid, out);").stepThis().dispose();
|
database.executeFast("CREATE INDEX IF NOT EXISTS mid_out_idx_messages ON messages(mid, out);").stepThis().dispose();
|
||||||
database.executeFast("CREATE INDEX IF NOT EXISTS task_idx_messages ON messages(uid, out, read_state, ttl, date, send_state);").stepThis().dispose();
|
database.executeFast("CREATE INDEX IF NOT EXISTS task_idx_messages ON messages(uid, out, read_state, ttl, date, send_state);").stepThis().dispose();
|
||||||
|
database.executeFast("CREATE INDEX IF NOT EXISTS send_state_idx_messages ON messages(mid, send_state, date) WHERE mid < 0 AND send_state = 1;").stepThis().dispose();
|
||||||
|
database.executeFast("PRAGMA user_version = 3").stepThis().dispose();
|
||||||
} else {
|
} else {
|
||||||
|
int version = database.executeInt("PRAGMA user_version");
|
||||||
|
if (version < 3) {
|
||||||
SQLiteCursor cursor = database.queryFinalized("SELECT count(*) FROM sqlite_master WHERE type='table' AND name='params'");
|
SQLiteCursor cursor = database.queryFinalized("SELECT count(*) FROM sqlite_master WHERE type='table' AND name='params'");
|
||||||
boolean create = false;
|
boolean create = false;
|
||||||
if (cursor.next()) {
|
if (cursor.next()) {
|
||||||
@ -169,6 +177,7 @@ public class MessagesStorage {
|
|||||||
database.executeFast("DROP INDEX IF EXISTS read_state_out_idx_messages;").stepThis().dispose();
|
database.executeFast("DROP INDEX IF EXISTS read_state_out_idx_messages;").stepThis().dispose();
|
||||||
database.executeFast("DROP INDEX IF EXISTS ttl_idx_messages;").stepThis().dispose();
|
database.executeFast("DROP INDEX IF EXISTS ttl_idx_messages;").stepThis().dispose();
|
||||||
database.executeFast("DROP INDEX IF EXISTS date_idx_messages;").stepThis().dispose();
|
database.executeFast("DROP INDEX IF EXISTS date_idx_messages;").stepThis().dispose();
|
||||||
|
database.executeFast("DROP INDEX IF EXISTS unread_count_idx_dialogs;").stepThis().dispose();
|
||||||
|
|
||||||
database.executeFast("CREATE INDEX IF NOT EXISTS mid_out_idx_messages ON messages(mid, out);").stepThis().dispose();
|
database.executeFast("CREATE INDEX IF NOT EXISTS mid_out_idx_messages ON messages(mid, out);").stepThis().dispose();
|
||||||
database.executeFast("CREATE INDEX IF NOT EXISTS task_idx_messages ON messages(uid, out, read_state, ttl, date, send_state);").stepThis().dispose();
|
database.executeFast("CREATE INDEX IF NOT EXISTS task_idx_messages ON messages(uid, out, read_state, ttl, date, send_state);").stepThis().dispose();
|
||||||
@ -182,13 +191,70 @@ public class MessagesStorage {
|
|||||||
|
|
||||||
database.executeFast("CREATE TABLE IF NOT EXISTS sent_files_v2(uid TEXT, type INTEGER, data BLOB, PRIMARY KEY (uid, type))").stepThis().dispose();
|
database.executeFast("CREATE TABLE IF NOT EXISTS sent_files_v2(uid TEXT, type INTEGER, data BLOB, PRIMARY KEY (uid, type))").stepThis().dispose();
|
||||||
|
|
||||||
database.executeFast("CREATE INDEX IF NOT EXISTS unread_count_idx_dialogs ON dialogs(unread_count);").stepThis().dispose();
|
database.executeFast("CREATE TABLE IF NOT EXISTS blocked_users(uid INTEGER PRIMARY KEY)").stepThis().dispose();
|
||||||
|
|
||||||
loadUnreadMessages();
|
database.executeFast("CREATE TABLE IF NOT EXISTS download_queue(uid INTEGER, type INTEGER, date INTEGER, data BLOB, PRIMARY KEY (uid, type));").stepThis().dispose();
|
||||||
|
database.executeFast("CREATE INDEX IF NOT EXISTS type_date_idx_download_queue ON download_queue(type, date);").stepThis().dispose();
|
||||||
|
|
||||||
|
database.executeFast("CREATE INDEX IF NOT EXISTS send_state_idx_messages ON messages(mid, send_state, date) WHERE mid < 0 AND send_state = 1;").stepThis().dispose();
|
||||||
|
|
||||||
|
database.executeFast("UPDATE messages SET send_state = 2 WHERE mid < 0 AND send_state = 1").stepThis().dispose();
|
||||||
|
|
||||||
|
database.executeFast("ALTER TABLE dialogs ADD COLUMN flags INTEGER NOT NULL default 0;").stepThis().dispose();
|
||||||
|
database.executeFast("CREATE INDEX IF NOT EXISTS unread_count_flags_idx_dialogs ON dialogs(unread_count, flags);").stepThis().dispose();
|
||||||
|
|
||||||
|
database.executeFast("PRAGMA user_version = 3").stepThis().dispose();
|
||||||
|
storageQueue.postRunnable(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
String ids = "";
|
||||||
|
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("Notifications", Context.MODE_PRIVATE);
|
||||||
|
Map<String, ?> values = preferences.getAll();
|
||||||
|
for (Map.Entry<String, ?> entry : values.entrySet()) {
|
||||||
|
String key = entry.getKey();
|
||||||
|
if (key.startsWith("notify2_")) {
|
||||||
|
Integer value = (Integer)entry.getValue();
|
||||||
|
if (value == 2) {
|
||||||
|
key = key.replace("notify2_", "");
|
||||||
|
if (ids.length() != 0) {
|
||||||
|
ids += ",";
|
||||||
|
}
|
||||||
|
ids += key;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
database.executeFast("UPDATE dialogs SET flags = 1 WHERE did IN (" + ids + ");").stepThis().dispose();
|
||||||
|
} catch (Exception e) {
|
||||||
|
FileLog.e("tmessages", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
SQLiteCursor cursor = database.queryFinalized("SELECT seq, pts, date, qts, lsv, sg, pbytes FROM params WHERE id = 1");
|
||||||
|
if (cursor.next()) {
|
||||||
|
lastSeqValue = cursor.intValue(0);
|
||||||
|
lastPtsValue = cursor.intValue(1);
|
||||||
|
lastDateValue = cursor.intValue(2);
|
||||||
|
lastQtsValue = cursor.intValue(3);
|
||||||
|
lastSecretVersion = cursor.intValue(4);
|
||||||
|
secretG = cursor.intValue(5);
|
||||||
|
if (cursor.isNull(6)) {
|
||||||
|
secretPBytes = null;
|
||||||
|
} else {
|
||||||
|
secretPBytes = cursor.byteArrayValue(6);
|
||||||
|
if (secretPBytes != null && secretPBytes.length == 1) {
|
||||||
|
secretPBytes = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
cursor.dispose();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
|
loadUnreadMessages(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void cleanUp(final boolean isLogin) {
|
public void cleanUp(final boolean isLogin) {
|
||||||
@ -279,23 +345,182 @@ public class MessagesStorage {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public void loadUnreadMessages() {
|
public void setDialogFlags(final long did, final int flags) {
|
||||||
|
storageQueue.postRunnable(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
database.executeFast("UPDATE dialogs SET flags = " + flags + " WHERE did = " + did).stepThis().dispose();
|
||||||
|
} catch (Exception e) {
|
||||||
|
FileLog.e("tmessages", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public void loadUnreadMessages(final boolean onlyCount) {
|
||||||
storageQueue.postRunnable(new Runnable() {
|
storageQueue.postRunnable(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
try {
|
try {
|
||||||
final HashMap<Long, Integer> pushDialogs = new HashMap<Long, Integer>();
|
final HashMap<Long, Integer> pushDialogs = new HashMap<Long, Integer>();
|
||||||
SQLiteCursor cursor = database.queryFinalized("SELECT did, unread_count FROM dialogs WHERE unread_count != 0");
|
SQLiteCursor cursor = database.queryFinalized("SELECT did, unread_count FROM dialogs WHERE unread_count != 0 AND flags != 1");
|
||||||
|
String ids = "";
|
||||||
while (cursor.next()) {
|
while (cursor.next()) {
|
||||||
long did = cursor.longValue(0);
|
long did = cursor.longValue(0);
|
||||||
int count = cursor.intValue(1);
|
int count = cursor.intValue(1);
|
||||||
pushDialogs.put(did, count);
|
pushDialogs.put(did, count);
|
||||||
|
if (!onlyCount) {
|
||||||
|
if (ids.length() != 0) {
|
||||||
|
ids += ",";
|
||||||
|
}
|
||||||
|
ids += did;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
cursor.dispose();
|
cursor.dispose();
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
|
||||||
|
final ArrayList<TLRPC.Message> messages = onlyCount ? null : new ArrayList<TLRPC.Message>();
|
||||||
|
final ArrayList<TLRPC.User> users = onlyCount ? null : new ArrayList<TLRPC.User>();
|
||||||
|
final ArrayList<TLRPC.Chat> chats = onlyCount ? null : new ArrayList<TLRPC.Chat>();
|
||||||
|
final ArrayList<TLRPC.EncryptedChat> encryptedChats = onlyCount ? null : new ArrayList<TLRPC.EncryptedChat>();
|
||||||
|
if (messages != null && ids.length() > 0) {
|
||||||
|
ArrayList<Integer> userIds = new ArrayList<Integer>();
|
||||||
|
ArrayList<Integer> chatIds = new ArrayList<Integer>();
|
||||||
|
ArrayList<Integer> encryptedChatIds = new ArrayList<Integer>();
|
||||||
|
|
||||||
|
cursor = database.queryFinalized("SELECT read_state, data, send_state, mid, date, uid FROM messages WHERE uid IN (" + ids + ") AND out = 0 AND read_state = 0 ORDER BY date DESC LIMIT 50");
|
||||||
|
while (cursor.next()) {
|
||||||
|
ByteBufferDesc data = buffersStorage.getFreeBuffer(cursor.byteArrayLength(1));
|
||||||
|
if (data != null && cursor.byteBufferValue(1, data.buffer) != 0) {
|
||||||
|
TLRPC.Message message = (TLRPC.Message)TLClassStore.Instance().TLdeserialize(data, data.readInt32());
|
||||||
|
int read_state = cursor.intValue(0);
|
||||||
|
message.unread = (cursor.intValue(0) != 1);
|
||||||
|
message.id = cursor.intValue(3);
|
||||||
|
message.date = cursor.intValue(4);
|
||||||
|
message.dialog_id = cursor.longValue(5);
|
||||||
|
messages.add(message);
|
||||||
|
|
||||||
|
int lower_id = (int)message.dialog_id;
|
||||||
|
int high_id = (int)(message.dialog_id >> 32);
|
||||||
|
|
||||||
|
if (lower_id != 0) {
|
||||||
|
if (lower_id < 0) {
|
||||||
|
if (!chatIds.contains(-lower_id)) {
|
||||||
|
chatIds.add(-lower_id);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (!userIds.contains(lower_id)) {
|
||||||
|
userIds.add(lower_id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (!encryptedChatIds.contains(high_id)) {
|
||||||
|
encryptedChatIds.add(high_id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!userIds.contains(message.from_id)) {
|
||||||
|
userIds.add(message.from_id);
|
||||||
|
}
|
||||||
|
if (message.action != null && message.action.user_id != 0 && !userIds.contains(message.action.user_id)) {
|
||||||
|
userIds.add(message.action.user_id);
|
||||||
|
}
|
||||||
|
if (message.media != null && message.media.user_id != 0 && !userIds.contains(message.media.user_id)) {
|
||||||
|
userIds.add(message.media.user_id);
|
||||||
|
}
|
||||||
|
if (message.media != null && message.media.audio != null && message.media.audio.user_id != 0 && !userIds.contains(message.media.audio.user_id)) {
|
||||||
|
userIds.add(message.media.audio.user_id);
|
||||||
|
}
|
||||||
|
if (message.fwd_from_id != 0 && !userIds.contains(message.fwd_from_id)) {
|
||||||
|
userIds.add(message.fwd_from_id);
|
||||||
|
}
|
||||||
|
message.send_state = cursor.intValue(2);
|
||||||
|
if (!message.unread && lower_id != 0 || message.id > 0) {
|
||||||
|
message.send_state = 0;
|
||||||
|
}
|
||||||
|
if (lower_id == 0 && !cursor.isNull(5)) {
|
||||||
|
message.random_id = cursor.longValue(5);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
buffersStorage.reuseFreeBuffer(data);
|
||||||
|
}
|
||||||
|
cursor.dispose();
|
||||||
|
|
||||||
|
String stringToLoad = "";
|
||||||
|
if (!encryptedChatIds.isEmpty()) {
|
||||||
|
for (int uid : encryptedChatIds) {
|
||||||
|
if (stringToLoad.length() != 0) {
|
||||||
|
stringToLoad += ",";
|
||||||
|
}
|
||||||
|
stringToLoad += uid;
|
||||||
|
}
|
||||||
|
cursor = database.queryFinalized(String.format(Locale.US, "SELECT data, user, g, authkey, ttl FROM enc_chats WHERE uid IN(%s)", stringToLoad));
|
||||||
|
while (cursor.next()) {
|
||||||
|
ByteBufferDesc data = buffersStorage.getFreeBuffer(cursor.byteArrayLength(0));
|
||||||
|
if (data != null && cursor.byteBufferValue(0, data.buffer) != 0) {
|
||||||
|
TLRPC.EncryptedChat chat = (TLRPC.EncryptedChat)TLClassStore.Instance().TLdeserialize(data, data.readInt32());
|
||||||
|
encryptedChats.add(chat);
|
||||||
|
chat.user_id = cursor.intValue(1);
|
||||||
|
if (!userIds.contains(chat.user_id)) {
|
||||||
|
userIds.add(chat.user_id);
|
||||||
|
}
|
||||||
|
chat.a_or_b = cursor.byteArrayValue(2);
|
||||||
|
chat.auth_key = cursor.byteArrayValue(3);
|
||||||
|
chat.ttl = cursor.intValue(4);
|
||||||
|
}
|
||||||
|
buffersStorage.reuseFreeBuffer(data);
|
||||||
|
}
|
||||||
|
cursor.dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!userIds.isEmpty()) {
|
||||||
|
stringToLoad = "";
|
||||||
|
for (Integer uid : userIds) {
|
||||||
|
if (stringToLoad.length() != 0) {
|
||||||
|
stringToLoad += ",";
|
||||||
|
}
|
||||||
|
stringToLoad += uid;
|
||||||
|
}
|
||||||
|
cursor = database.queryFinalized(String.format(Locale.US, "SELECT data, status FROM users WHERE uid IN(%s)", stringToLoad));
|
||||||
|
while (cursor.next()) {
|
||||||
|
ByteBufferDesc data = buffersStorage.getFreeBuffer(cursor.byteArrayLength(0));
|
||||||
|
if (data != null && cursor.byteBufferValue(0, data.buffer) != 0) {
|
||||||
|
TLRPC.User user = (TLRPC.User) TLClassStore.Instance().TLdeserialize(data, data.readInt32());
|
||||||
|
if (user.status != null) {
|
||||||
|
user.status.expires = cursor.intValue(1);
|
||||||
|
}
|
||||||
|
users.add(user);
|
||||||
|
}
|
||||||
|
buffersStorage.reuseFreeBuffer(data);
|
||||||
|
}
|
||||||
|
cursor.dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!chatIds.isEmpty()) {
|
||||||
|
stringToLoad = "";
|
||||||
|
for (Integer cid : chatIds) {
|
||||||
|
if (stringToLoad.length() != 0) {
|
||||||
|
stringToLoad += ",";
|
||||||
|
}
|
||||||
|
stringToLoad += cid;
|
||||||
|
}
|
||||||
|
cursor = database.queryFinalized(String.format(Locale.US, "SELECT data FROM chats WHERE uid IN(%s)", stringToLoad));
|
||||||
|
while (cursor.next()) {
|
||||||
|
ByteBufferDesc data = buffersStorage.getFreeBuffer(cursor.byteArrayLength(0));
|
||||||
|
if (data != null && cursor.byteBufferValue(0, data.buffer) != 0) {
|
||||||
|
TLRPC.Chat chat = (TLRPC.Chat) TLClassStore.Instance().TLdeserialize(data, data.readInt32());
|
||||||
|
chats.add(chat);
|
||||||
|
}
|
||||||
|
buffersStorage.reuseFreeBuffer(data);
|
||||||
|
}
|
||||||
|
cursor.dispose();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
NotificationsController.getInstance().processLoadedUnreadMessages(pushDialogs);
|
NotificationsController.getInstance().processLoadedUnreadMessages(pushDialogs, messages, users, chats, encryptedChats);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
@ -349,7 +574,90 @@ public class MessagesStorage {
|
|||||||
buffersStorage.reuseFreeBuffer(data);
|
buffersStorage.reuseFreeBuffer(data);
|
||||||
}
|
}
|
||||||
cursor.dispose();
|
cursor.dispose();
|
||||||
NotificationCenter.getInstance().postNotificationName(wallpapersDidLoaded, wallPapers);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.wallpapersDidLoaded, wallPapers);
|
||||||
|
} catch (Exception e) {
|
||||||
|
FileLog.e("tmessages", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public void getBlockedUsers() {
|
||||||
|
storageQueue.postRunnable(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
ArrayList<Integer> ids = new ArrayList<Integer>();
|
||||||
|
ArrayList<TLRPC.User> users = new ArrayList<TLRPC.User>();
|
||||||
|
SQLiteCursor cursor = database.queryFinalized(String.format(Locale.US, "SELECT * FROM blocked_users WHERE 1"));
|
||||||
|
String usersToLoad = "";
|
||||||
|
while (cursor.next()) {
|
||||||
|
int user_id = cursor.intValue(0);
|
||||||
|
ids.add(user_id);
|
||||||
|
if (usersToLoad.length() != 0) {
|
||||||
|
usersToLoad += ",";
|
||||||
|
}
|
||||||
|
usersToLoad += user_id;
|
||||||
|
}
|
||||||
|
cursor.dispose();
|
||||||
|
|
||||||
|
if (usersToLoad.length() != 0) {
|
||||||
|
cursor = database.queryFinalized(String.format(Locale.US, "SELECT data, status FROM users WHERE uid IN(%s)", usersToLoad));
|
||||||
|
while (cursor.next()) {
|
||||||
|
ByteBufferDesc data = buffersStorage.getFreeBuffer(cursor.byteArrayLength(0));
|
||||||
|
if (data != null && cursor.byteBufferValue(0, data.buffer) != 0) {
|
||||||
|
TLRPC.User user = (TLRPC.User)TLClassStore.Instance().TLdeserialize(data, data.readInt32());
|
||||||
|
users.add(user);
|
||||||
|
if (user.status != null) {
|
||||||
|
user.status.expires = cursor.intValue(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
buffersStorage.reuseFreeBuffer(data);
|
||||||
|
}
|
||||||
|
cursor.dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
MessagesController.getInstance().processLoadedBlockedUsers(ids, users, true);
|
||||||
|
} catch (Exception e) {
|
||||||
|
FileLog.e("tmessages", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public void deleteBlockedUser(final int id) {
|
||||||
|
storageQueue.postRunnable(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
database.executeFast("DELETE FROM blocked_users WHERE uid = " + id).stepThis().dispose();
|
||||||
|
} catch (Exception e) {
|
||||||
|
FileLog.e("tmessages", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public void putBlockedUsers(final ArrayList<Integer> ids, final boolean replace) {
|
||||||
|
if (ids == null || ids.isEmpty()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
storageQueue.postRunnable(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
if (replace) {
|
||||||
|
database.executeFast("DELETE FROM blocked_users WHERE 1").stepThis().dispose();
|
||||||
|
}
|
||||||
|
database.beginTransaction();
|
||||||
|
SQLitePreparedStatement state = database.executeFast("REPLACE INTO blocked_users VALUES(?)");
|
||||||
|
for (Integer id : ids) {
|
||||||
|
state.requery();
|
||||||
|
state.bindInteger(1, id);
|
||||||
|
state.step();
|
||||||
|
}
|
||||||
|
state.dispose();
|
||||||
|
database.commitTransaction();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
@ -419,7 +727,6 @@ public class MessagesStorage {
|
|||||||
MessagesController.getInstance().processLoadedUserPhotos(res, uid, offset, count, max_id, true, classGuid);
|
MessagesController.getInstance().processLoadedUserPhotos(res, uid, offset, count, max_id, true, classGuid);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
@ -440,6 +747,19 @@ public class MessagesStorage {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void clearUserPhoto(final int uid, final long pid) {
|
||||||
|
storageQueue.postRunnable(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
database.executeFast("DELETE FROM user_photos WHERE uid = " + uid + " AND id = " + pid).stepThis().dispose();
|
||||||
|
} catch (Exception e) {
|
||||||
|
FileLog.e("tmessages", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
public void putUserPhotos(final int uid, final TLRPC.photos_Photos photos) {
|
public void putUserPhotos(final int uid, final TLRPC.photos_Photos photos) {
|
||||||
if (photos == null || photos.photos.isEmpty()) {
|
if (photos == null || photos.photos.isEmpty()) {
|
||||||
return;
|
return;
|
||||||
@ -732,10 +1052,10 @@ public class MessagesStorage {
|
|||||||
info.version = version;
|
info.version = version;
|
||||||
|
|
||||||
final TLRPC.ChatParticipants finalInfo = info;
|
final TLRPC.ChatParticipants finalInfo = info;
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.chatInfoDidLoaded, finalInfo.chat_id, finalInfo);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.chatInfoDidLoaded, finalInfo.chat_id, finalInfo);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -881,7 +1201,7 @@ public class MessagesStorage {
|
|||||||
ArrayList<TLRPC.User> encUsers = new ArrayList<TLRPC.User>();
|
ArrayList<TLRPC.User> encUsers = new ArrayList<TLRPC.User>();
|
||||||
String q = query.trim().toLowerCase();
|
String q = query.trim().toLowerCase();
|
||||||
if (q.length() == 0) {
|
if (q.length() == 0) {
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.reloadSearchResults, token, new ArrayList<TLObject>(), new ArrayList<CharSequence>(), new ArrayList<CharSequence>());
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.reloadSearchResults, token, new ArrayList<TLObject>(), new ArrayList<CharSequence>(), new ArrayList<CharSequence>());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
ArrayList<TLObject> resultArray = new ArrayList<TLObject>();
|
ArrayList<TLObject> resultArray = new ArrayList<TLObject>();
|
||||||
@ -966,7 +1286,7 @@ public class MessagesStorage {
|
|||||||
}
|
}
|
||||||
cursor.dispose();
|
cursor.dispose();
|
||||||
|
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.reloadSearchResults, token, resultArray, resultArrayNames, encUsers);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.reloadSearchResults, token, resultArray, resultArrayNames, encUsers);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
@ -1329,6 +1649,172 @@ public class MessagesStorage {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void getUnsentMessages(final int count) {
|
||||||
|
storageQueue.postRunnable(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
ArrayList<TLRPC.Message> messages = new ArrayList<TLRPC.Message>();
|
||||||
|
ArrayList<TLRPC.User> users = new ArrayList<TLRPC.User>();
|
||||||
|
ArrayList<TLRPC.Chat> chats = new ArrayList<TLRPC.Chat>();
|
||||||
|
ArrayList<TLRPC.EncryptedChat> encryptedChats = new ArrayList<TLRPC.EncryptedChat>();
|
||||||
|
|
||||||
|
ArrayList<Integer> userIds = new ArrayList<Integer>();
|
||||||
|
ArrayList<Integer> chatIds = new ArrayList<Integer>();
|
||||||
|
ArrayList<Integer> broadcastIds = new ArrayList<Integer>();
|
||||||
|
ArrayList<Integer> encryptedChatIds = new ArrayList<Integer>();
|
||||||
|
SQLiteCursor cursor = database.queryFinalized("SELECT m.read_state, m.data, m.send_state, m.mid, m.date, r.random_id, m.uid FROM messages as m LEFT JOIN randoms as r ON r.mid = m.mid WHERE m.mid < 0 AND m.send_state = 1 ORDER BY m.mid DESC LIMIT " + count);
|
||||||
|
while (cursor.next()) {
|
||||||
|
ByteBufferDesc data = buffersStorage.getFreeBuffer(cursor.byteArrayLength(1));
|
||||||
|
if (data != null && cursor.byteBufferValue(1, data.buffer) != 0) {
|
||||||
|
TLRPC.Message message = (TLRPC.Message)TLClassStore.Instance().TLdeserialize(data, data.readInt32());
|
||||||
|
int read_state = cursor.intValue(0);
|
||||||
|
message.unread = (cursor.intValue(0) != 1);
|
||||||
|
message.id = cursor.intValue(3);
|
||||||
|
message.date = cursor.intValue(4);
|
||||||
|
if (!cursor.isNull(5)) {
|
||||||
|
message.random_id = cursor.longValue(5);
|
||||||
|
}
|
||||||
|
message.dialog_id = cursor.longValue(6);
|
||||||
|
messages.add(message);
|
||||||
|
|
||||||
|
int lower_id = (int)message.dialog_id;
|
||||||
|
int high_id = (int)(message.dialog_id >> 32);
|
||||||
|
|
||||||
|
if (lower_id != 0) {
|
||||||
|
if (high_id == 1) {
|
||||||
|
if (!broadcastIds.contains(lower_id)) {
|
||||||
|
broadcastIds.add(lower_id);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (lower_id < 0) {
|
||||||
|
if (!chatIds.contains(-lower_id)) {
|
||||||
|
chatIds.add(-lower_id);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (!userIds.contains(lower_id)) {
|
||||||
|
userIds.add(lower_id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (!encryptedChatIds.contains(high_id)) {
|
||||||
|
encryptedChatIds.add(high_id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!userIds.contains(message.from_id)) {
|
||||||
|
userIds.add(message.from_id);
|
||||||
|
}
|
||||||
|
if (message.action != null && message.action.user_id != 0 && !userIds.contains(message.action.user_id)) {
|
||||||
|
userIds.add(message.action.user_id);
|
||||||
|
}
|
||||||
|
if (message.media != null && message.media.user_id != 0 && !userIds.contains(message.media.user_id)) {
|
||||||
|
userIds.add(message.media.user_id);
|
||||||
|
}
|
||||||
|
if (message.media != null && message.media.audio != null && message.media.audio.user_id != 0 && !userIds.contains(message.media.audio.user_id)) {
|
||||||
|
userIds.add(message.media.audio.user_id);
|
||||||
|
}
|
||||||
|
if (message.fwd_from_id != 0 && !userIds.contains(message.fwd_from_id)) {
|
||||||
|
userIds.add(message.fwd_from_id);
|
||||||
|
}
|
||||||
|
message.send_state = cursor.intValue(2);
|
||||||
|
if (!message.unread && lower_id != 0 || message.id > 0) {
|
||||||
|
message.send_state = 0;
|
||||||
|
}
|
||||||
|
if (lower_id == 0 && !cursor.isNull(5)) {
|
||||||
|
message.random_id = cursor.longValue(5);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
buffersStorage.reuseFreeBuffer(data);
|
||||||
|
}
|
||||||
|
cursor.dispose();
|
||||||
|
|
||||||
|
String stringToLoad = "";
|
||||||
|
if (!encryptedChatIds.isEmpty()) {
|
||||||
|
for (int uid : encryptedChatIds) {
|
||||||
|
if (stringToLoad.length() != 0) {
|
||||||
|
stringToLoad += ",";
|
||||||
|
}
|
||||||
|
stringToLoad += uid;
|
||||||
|
}
|
||||||
|
cursor = database.queryFinalized(String.format(Locale.US, "SELECT data, user, g, authkey, ttl FROM enc_chats WHERE uid IN(%s)", stringToLoad));
|
||||||
|
while (cursor.next()) {
|
||||||
|
ByteBufferDesc data = buffersStorage.getFreeBuffer(cursor.byteArrayLength(0));
|
||||||
|
if (data != null && cursor.byteBufferValue(0, data.buffer) != 0) {
|
||||||
|
TLRPC.EncryptedChat chat = (TLRPC.EncryptedChat)TLClassStore.Instance().TLdeserialize(data, data.readInt32());
|
||||||
|
encryptedChats.add(chat);
|
||||||
|
chat.user_id = cursor.intValue(1);
|
||||||
|
if (!userIds.contains(chat.user_id)) {
|
||||||
|
userIds.add(chat.user_id);
|
||||||
|
}
|
||||||
|
chat.a_or_b = cursor.byteArrayValue(2);
|
||||||
|
chat.auth_key = cursor.byteArrayValue(3);
|
||||||
|
chat.ttl = cursor.intValue(4);
|
||||||
|
}
|
||||||
|
buffersStorage.reuseFreeBuffer(data);
|
||||||
|
}
|
||||||
|
cursor.dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (!userIds.isEmpty()) {
|
||||||
|
stringToLoad = "";
|
||||||
|
for (Integer uid : userIds) {
|
||||||
|
if (stringToLoad.length() != 0) {
|
||||||
|
stringToLoad += ",";
|
||||||
|
}
|
||||||
|
stringToLoad += uid;
|
||||||
|
}
|
||||||
|
cursor = database.queryFinalized(String.format(Locale.US, "SELECT data, status FROM users WHERE uid IN(%s)", stringToLoad));
|
||||||
|
while (cursor.next()) {
|
||||||
|
ByteBufferDesc data = buffersStorage.getFreeBuffer(cursor.byteArrayLength(0));
|
||||||
|
if (data != null && cursor.byteBufferValue(0, data.buffer) != 0) {
|
||||||
|
TLRPC.User user = (TLRPC.User) TLClassStore.Instance().TLdeserialize(data, data.readInt32());
|
||||||
|
if (user.status != null) {
|
||||||
|
user.status.expires = cursor.intValue(1);
|
||||||
|
}
|
||||||
|
users.add(user);
|
||||||
|
}
|
||||||
|
buffersStorage.reuseFreeBuffer(data);
|
||||||
|
}
|
||||||
|
cursor.dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!chatIds.isEmpty() || !broadcastIds.isEmpty()) {
|
||||||
|
stringToLoad = "";
|
||||||
|
for (Integer cid : chatIds) {
|
||||||
|
if (stringToLoad.length() != 0) {
|
||||||
|
stringToLoad += ",";
|
||||||
|
}
|
||||||
|
stringToLoad += cid;
|
||||||
|
}
|
||||||
|
for (Integer cid : broadcastIds) {
|
||||||
|
if (stringToLoad.length() != 0) {
|
||||||
|
stringToLoad += ",";
|
||||||
|
}
|
||||||
|
stringToLoad += (-cid);
|
||||||
|
}
|
||||||
|
cursor = database.queryFinalized(String.format(Locale.US, "SELECT data FROM chats WHERE uid IN(%s)", stringToLoad));
|
||||||
|
while (cursor.next()) {
|
||||||
|
ByteBufferDesc data = buffersStorage.getFreeBuffer(cursor.byteArrayLength(0));
|
||||||
|
if (data != null && cursor.byteBufferValue(0, data.buffer) != 0) {
|
||||||
|
TLRPC.Chat chat = (TLRPC.Chat) TLClassStore.Instance().TLdeserialize(data, data.readInt32());
|
||||||
|
chats.add(chat);
|
||||||
|
}
|
||||||
|
buffersStorage.reuseFreeBuffer(data);
|
||||||
|
}
|
||||||
|
cursor.dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
SendMessagesHelper.getInstance().processUnsentMessages(messages, users, chats, encryptedChats);
|
||||||
|
} catch (Exception e) {
|
||||||
|
FileLog.e("tmessages", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
public void getMessages(final long dialog_id, final int count, final int max_id, final int minDate, final int classGuid, final boolean from_unread, final boolean forward) {
|
public void getMessages(final long dialog_id, final int count, final int max_id, final int minDate, final int classGuid, final boolean from_unread, final boolean forward) {
|
||||||
storageQueue.postRunnable(new Runnable() {
|
storageQueue.postRunnable(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
@ -1758,11 +2244,12 @@ public class MessagesStorage {
|
|||||||
buffersStorage.reuseFreeBuffer(data3);
|
buffersStorage.reuseFreeBuffer(data3);
|
||||||
|
|
||||||
if (dialog != null) {
|
if (dialog != null) {
|
||||||
state = database.executeFast("REPLACE INTO dialogs VALUES(?, ?, ?, ?)");
|
state = database.executeFast("REPLACE INTO dialogs VALUES(?, ?, ?, ?, ?)");
|
||||||
state.bindLong(1, dialog.id);
|
state.bindLong(1, dialog.id);
|
||||||
state.bindInteger(2, dialog.last_message_date);
|
state.bindInteger(2, dialog.last_message_date);
|
||||||
state.bindInteger(3, dialog.unread_count);
|
state.bindInteger(3, dialog.unread_count);
|
||||||
state.bindInteger(4, dialog.top_message);
|
state.bindInteger(4, dialog.top_message);
|
||||||
|
state.bindInteger(5, dialog.flags);
|
||||||
state.step();
|
state.step();
|
||||||
state.dispose();
|
state.dispose();
|
||||||
}
|
}
|
||||||
@ -1848,7 +2335,70 @@ public class MessagesStorage {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void putMessagesInternal(final ArrayList<TLRPC.Message> messages, final boolean withTransaction, final boolean isBroadcast) {
|
public void removeFromDownloadQueue(final long id, final int type) {
|
||||||
|
storageQueue.postRunnable(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
database.executeFast(String.format(Locale.US, "DELETE FROM download_queue WHERE uid = %d AND type = %d", id, type)).stepThis().dispose();
|
||||||
|
} catch (Exception e) {
|
||||||
|
FileLog.e("tmessages", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public void clearDownloadQueue(final int type) {
|
||||||
|
storageQueue.postRunnable(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
if (type == 0) {
|
||||||
|
database.executeFast("DELETE FROM download_queue WHERE 1").stepThis().dispose();
|
||||||
|
} else {
|
||||||
|
database.executeFast(String.format(Locale.US, "DELETE FROM download_queue WHERE type = %d", type)).stepThis().dispose();
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
FileLog.e("tmessages", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public void getDownloadQueue(final int type) {
|
||||||
|
storageQueue.postRunnable(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
final ArrayList<DownloadObject> objects = new ArrayList<DownloadObject>();
|
||||||
|
SQLiteCursor cursor = database.queryFinalized(String.format(Locale.US, "SELECT uid, type, data FROM download_queue WHERE type = %d ORDER BY date DESC LIMIT 3", type));
|
||||||
|
while (cursor.next()) {
|
||||||
|
DownloadObject downloadObject = new DownloadObject();
|
||||||
|
downloadObject.type = cursor.intValue(1);
|
||||||
|
downloadObject.id = cursor.longValue(0);
|
||||||
|
ByteBufferDesc data = buffersStorage.getFreeBuffer(cursor.byteArrayLength(2));
|
||||||
|
if (data != null && cursor.byteBufferValue(2, data.buffer) != 0) {
|
||||||
|
downloadObject.object = TLClassStore.Instance().TLdeserialize(data, data.readInt32());
|
||||||
|
}
|
||||||
|
buffersStorage.reuseFreeBuffer(data);
|
||||||
|
objects.add(downloadObject);
|
||||||
|
}
|
||||||
|
cursor.dispose();
|
||||||
|
|
||||||
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
MediaController.getInstance().processDownloadObjects(type, objects);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} catch (Exception e) {
|
||||||
|
FileLog.e("tmessages", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void putMessagesInternal(final ArrayList<TLRPC.Message> messages, final boolean withTransaction, final boolean isBroadcast, final int downloadMask) {
|
||||||
try {
|
try {
|
||||||
if (withTransaction) {
|
if (withTransaction) {
|
||||||
database.beginTransaction();
|
database.beginTransaction();
|
||||||
@ -1863,6 +2413,7 @@ public class MessagesStorage {
|
|||||||
SQLitePreparedStatement state = database.executeFast("REPLACE INTO messages VALUES(?, ?, ?, ?, ?, ?, ?, ?)");
|
SQLitePreparedStatement state = database.executeFast("REPLACE INTO messages VALUES(?, ?, ?, ?, ?, ?, ?, ?)");
|
||||||
SQLitePreparedStatement state2 = database.executeFast("REPLACE INTO media VALUES(?, ?, ?, ?)");
|
SQLitePreparedStatement state2 = database.executeFast("REPLACE INTO media VALUES(?, ?, ?, ?)");
|
||||||
SQLitePreparedStatement state3 = database.executeFast("REPLACE INTO randoms VALUES(?, ?)");
|
SQLitePreparedStatement state3 = database.executeFast("REPLACE INTO randoms VALUES(?, ?)");
|
||||||
|
SQLitePreparedStatement state4 = database.executeFast("REPLACE INTO download_queue VALUES(?, ?, ?, ?)");
|
||||||
|
|
||||||
for (TLRPC.Message message : messages) {
|
for (TLRPC.Message message : messages) {
|
||||||
long dialog_id = 0;
|
long dialog_id = 0;
|
||||||
@ -1937,6 +2488,7 @@ public class MessagesStorage {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int downloadMediaMask = 0;
|
||||||
for (TLRPC.Message message : messages) {
|
for (TLRPC.Message message : messages) {
|
||||||
long dialog_id = message.dialog_id;
|
long dialog_id = message.dialog_id;
|
||||||
if (dialog_id == 0) {
|
if (dialog_id == 0) {
|
||||||
@ -1985,21 +2537,72 @@ public class MessagesStorage {
|
|||||||
state2.step();
|
state2.step();
|
||||||
}
|
}
|
||||||
buffersStorage.reuseFreeBuffer(data);
|
buffersStorage.reuseFreeBuffer(data);
|
||||||
|
|
||||||
|
if (downloadMask != 0) {
|
||||||
|
if (message.media instanceof TLRPC.TL_messageMediaAudio || message.media instanceof TLRPC.TL_messageMediaPhoto || message.media instanceof TLRPC.TL_messageMediaVideo || message.media instanceof TLRPC.TL_messageMediaDocument) {
|
||||||
|
int type = 0;
|
||||||
|
long id = 0;
|
||||||
|
TLObject object = null;
|
||||||
|
if (message.media instanceof TLRPC.TL_messageMediaAudio) {
|
||||||
|
if ((downloadMask & MediaController.AUTODOWNLOAD_MASK_AUDIO) != 0) {
|
||||||
|
id = message.media.audio.id;
|
||||||
|
type = MediaController.AUTODOWNLOAD_MASK_AUDIO;
|
||||||
|
object = message.media.audio;
|
||||||
|
}
|
||||||
|
} else if (message.media instanceof TLRPC.TL_messageMediaPhoto) {
|
||||||
|
if ((downloadMask & MediaController.AUTODOWNLOAD_MASK_PHOTO) != 0) {
|
||||||
|
TLRPC.PhotoSize photoSize = PhotoObject.getClosestPhotoSizeWithSize(message.media.photo.sizes, 800, 800);
|
||||||
|
if (photoSize != null) {
|
||||||
|
id = message.media.photo.id;
|
||||||
|
type = MediaController.AUTODOWNLOAD_MASK_PHOTO;
|
||||||
|
object = photoSize;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (message.media instanceof TLRPC.TL_messageMediaVideo) {
|
||||||
|
if ((downloadMask & MediaController.AUTODOWNLOAD_MASK_VIDEO) != 0) {
|
||||||
|
id = message.media.video.id;
|
||||||
|
type = MediaController.AUTODOWNLOAD_MASK_VIDEO;
|
||||||
|
object = message.media.video;
|
||||||
|
}
|
||||||
|
} else if (message.media instanceof TLRPC.TL_messageMediaDocument) {
|
||||||
|
if ((downloadMask & MediaController.AUTODOWNLOAD_MASK_DOCUMENT) != 0) {
|
||||||
|
id = message.media.document.id;
|
||||||
|
type = MediaController.AUTODOWNLOAD_MASK_DOCUMENT;
|
||||||
|
object = message.media.document;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (object != null) {
|
||||||
|
downloadMediaMask |= type;
|
||||||
|
state4.requery();
|
||||||
|
data = buffersStorage.getFreeBuffer(object.getObjectSize());
|
||||||
|
object.serializeToStream(data);
|
||||||
|
state4.bindLong(1, id);
|
||||||
|
state4.bindInteger(2, type);
|
||||||
|
state4.bindInteger(3, message.date);
|
||||||
|
state4.bindByteBuffer(4, data.buffer);
|
||||||
|
state4.step();
|
||||||
|
buffersStorage.reuseFreeBuffer(data);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
state.dispose();
|
state.dispose();
|
||||||
state2.dispose();
|
state2.dispose();
|
||||||
state3.dispose();
|
state3.dispose();
|
||||||
|
state4.dispose();
|
||||||
|
|
||||||
state = database.executeFast("REPLACE INTO dialogs VALUES(?, ?, ?, ?)");
|
state = database.executeFast("REPLACE INTO dialogs VALUES(?, ?, ?, ?, ?)");
|
||||||
for (HashMap.Entry<Long, TLRPC.Message> pair : messagesMap.entrySet()) {
|
for (HashMap.Entry<Long, TLRPC.Message> pair : messagesMap.entrySet()) {
|
||||||
Long key = pair.getKey();
|
Long key = pair.getKey();
|
||||||
|
|
||||||
int dialog_date = 0;
|
int dialog_date = 0;
|
||||||
int old_unread_count = 0;
|
int old_unread_count = 0;
|
||||||
SQLiteCursor cursor = database.queryFinalized("SELECT date, unread_count FROM dialogs WHERE did = " + key);
|
int old_flags = 0;
|
||||||
|
SQLiteCursor cursor = database.queryFinalized("SELECT date, unread_count, flags FROM dialogs WHERE did = " + key);
|
||||||
if (cursor.next()) {
|
if (cursor.next()) {
|
||||||
dialog_date = cursor.intValue(0);
|
dialog_date = cursor.intValue(0);
|
||||||
old_unread_count = cursor.intValue(1);
|
old_unread_count = cursor.intValue(1);
|
||||||
|
old_flags = cursor.intValue(2);
|
||||||
}
|
}
|
||||||
cursor.dispose();
|
cursor.dispose();
|
||||||
|
|
||||||
@ -2008,6 +2611,8 @@ public class MessagesStorage {
|
|||||||
Integer unread_count = messagesCounts.get(key);
|
Integer unread_count = messagesCounts.get(key);
|
||||||
if (unread_count == null) {
|
if (unread_count == null) {
|
||||||
unread_count = 0;
|
unread_count = 0;
|
||||||
|
} else {
|
||||||
|
messagesCounts.put(key, -(unread_count + old_unread_count));
|
||||||
}
|
}
|
||||||
int messageId = value.id;
|
int messageId = value.id;
|
||||||
if (value.local_id != 0) {
|
if (value.local_id != 0) {
|
||||||
@ -2021,6 +2626,7 @@ public class MessagesStorage {
|
|||||||
}
|
}
|
||||||
state.bindInteger(3, old_unread_count + unread_count);
|
state.bindInteger(3, old_unread_count + unread_count);
|
||||||
state.bindInteger(4, messageId);
|
state.bindInteger(4, messageId);
|
||||||
|
state.bindInteger(5, old_flags);
|
||||||
state.step();
|
state.step();
|
||||||
}
|
}
|
||||||
state.dispose();
|
state.dispose();
|
||||||
@ -2051,12 +2657,21 @@ public class MessagesStorage {
|
|||||||
state.dispose();
|
state.dispose();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (downloadMediaMask != 0) {
|
||||||
|
final int downloadMediaMaskFinal = downloadMediaMask;
|
||||||
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
MediaController.getInstance().newDownloadObjectsAvailable(downloadMediaMaskFinal);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void putMessages(final ArrayList<TLRPC.Message> messages, final boolean withTransaction, boolean useQueue, final boolean isBroadcast) {
|
public void putMessages(final ArrayList<TLRPC.Message> messages, final boolean withTransaction, boolean useQueue, final boolean isBroadcast, final int downloadMask) {
|
||||||
if (messages.size() == 0) {
|
if (messages.size() == 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -2064,11 +2679,11 @@ public class MessagesStorage {
|
|||||||
storageQueue.postRunnable(new Runnable() {
|
storageQueue.postRunnable(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
putMessagesInternal(messages, withTransaction, isBroadcast);
|
putMessagesInternal(messages, withTransaction, isBroadcast, downloadMask);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
putMessagesInternal(messages, withTransaction, isBroadcast);
|
putMessagesInternal(messages, withTransaction, isBroadcast, downloadMask);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2348,7 +2963,7 @@ public class MessagesStorage {
|
|||||||
}
|
}
|
||||||
cursor.dispose();
|
cursor.dispose();
|
||||||
if (!mids.isEmpty()) {
|
if (!mids.isEmpty()) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
for (Integer id : mids) {
|
for (Integer id : mids) {
|
||||||
@ -2357,7 +2972,7 @@ public class MessagesStorage {
|
|||||||
obj.deleted = true;
|
obj.deleted = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.messagesDeleted, mids);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.messagesDeleted, mids);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
MessagesStorage.getInstance().markMessagesAsDeletedInternal(mids);
|
MessagesStorage.getInstance().markMessagesAsDeletedInternal(mids);
|
||||||
@ -2434,13 +3049,14 @@ public class MessagesStorage {
|
|||||||
ArrayList<Integer> usersToLoad = new ArrayList<Integer>();
|
ArrayList<Integer> usersToLoad = new ArrayList<Integer>();
|
||||||
ArrayList<Integer> chatsToLoad = new ArrayList<Integer>();
|
ArrayList<Integer> chatsToLoad = new ArrayList<Integer>();
|
||||||
ArrayList<Integer> encryptedToLoad = new ArrayList<Integer>();
|
ArrayList<Integer> encryptedToLoad = new ArrayList<Integer>();
|
||||||
cursor = database.queryFinalized(String.format(Locale.US, "SELECT d.did, d.last_mid, d.unread_count, d.date, m.data, m.read_state, m.mid, m.send_state FROM dialogs as d LEFT JOIN messages as m ON d.last_mid = m.mid WHERE d.did IN(%s)", ids));
|
cursor = database.queryFinalized(String.format(Locale.US, "SELECT d.did, d.last_mid, d.unread_count, d.date, m.data, m.read_state, m.mid, m.send_state, d.flags FROM dialogs as d LEFT JOIN messages as m ON d.last_mid = m.mid WHERE d.did IN(%s)", ids));
|
||||||
while (cursor.next()) {
|
while (cursor.next()) {
|
||||||
TLRPC.TL_dialog dialog = new TLRPC.TL_dialog();
|
TLRPC.TL_dialog dialog = new TLRPC.TL_dialog();
|
||||||
dialog.id = cursor.longValue(0);
|
dialog.id = cursor.longValue(0);
|
||||||
dialog.top_message = cursor.intValue(1);
|
dialog.top_message = cursor.intValue(1);
|
||||||
dialog.unread_count = cursor.intValue(2);
|
dialog.unread_count = cursor.intValue(2);
|
||||||
dialog.last_message_date = cursor.intValue(3);
|
dialog.last_message_date = cursor.intValue(3);
|
||||||
|
dialog.flags = cursor.intValue(8);
|
||||||
dialogs.dialogs.add(dialog);
|
dialogs.dialogs.add(dialog);
|
||||||
|
|
||||||
ByteBufferDesc data = buffersStorage.getFreeBuffer(cursor.byteArrayLength(4));
|
ByteBufferDesc data = buffersStorage.getFreeBuffer(cursor.byteArrayLength(4));
|
||||||
@ -2705,13 +3321,14 @@ public class MessagesStorage {
|
|||||||
usersToLoad.add(UserConfig.getClientUserId());
|
usersToLoad.add(UserConfig.getClientUserId());
|
||||||
ArrayList<Integer> chatsToLoad = new ArrayList<Integer>();
|
ArrayList<Integer> chatsToLoad = new ArrayList<Integer>();
|
||||||
ArrayList<Integer> encryptedToLoad = new ArrayList<Integer>();
|
ArrayList<Integer> encryptedToLoad = new ArrayList<Integer>();
|
||||||
SQLiteCursor cursor = database.queryFinalized(String.format(Locale.US, "SELECT d.did, d.last_mid, d.unread_count, d.date, m.data, m.read_state, m.mid, m.send_state FROM dialogs as d LEFT JOIN messages as m ON d.last_mid = m.mid ORDER BY d.date DESC LIMIT %d,%d", offset, count));
|
SQLiteCursor cursor = database.queryFinalized(String.format(Locale.US, "SELECT d.did, d.last_mid, d.unread_count, d.date, m.data, m.read_state, m.mid, m.send_state, d.flags FROM dialogs as d LEFT JOIN messages as m ON d.last_mid = m.mid ORDER BY d.date DESC LIMIT %d,%d", offset, count));
|
||||||
while (cursor.next()) {
|
while (cursor.next()) {
|
||||||
TLRPC.TL_dialog dialog = new TLRPC.TL_dialog();
|
TLRPC.TL_dialog dialog = new TLRPC.TL_dialog();
|
||||||
dialog.id = cursor.longValue(0);
|
dialog.id = cursor.longValue(0);
|
||||||
dialog.top_message = cursor.intValue(1);
|
dialog.top_message = cursor.intValue(1);
|
||||||
dialog.unread_count = cursor.intValue(2);
|
dialog.unread_count = cursor.intValue(2);
|
||||||
dialog.last_message_date = cursor.intValue(3);
|
dialog.last_message_date = cursor.intValue(3);
|
||||||
|
dialog.flags = cursor.intValue(8);
|
||||||
dialogs.dialogs.add(dialog);
|
dialogs.dialogs.add(dialog);
|
||||||
|
|
||||||
ByteBufferDesc data = buffersStorage.getFreeBuffer(cursor.byteArrayLength(4));
|
ByteBufferDesc data = buffersStorage.getFreeBuffer(cursor.byteArrayLength(4));
|
||||||
@ -2887,7 +3504,7 @@ public class MessagesStorage {
|
|||||||
|
|
||||||
if (!dialogs.dialogs.isEmpty()) {
|
if (!dialogs.dialogs.isEmpty()) {
|
||||||
SQLitePreparedStatement state = database.executeFast("REPLACE INTO messages VALUES(?, ?, ?, ?, ?, ?, ?, ?)");
|
SQLitePreparedStatement state = database.executeFast("REPLACE INTO messages VALUES(?, ?, ?, ?, ?, ?, ?, ?)");
|
||||||
SQLitePreparedStatement state2 = database.executeFast("REPLACE INTO dialogs VALUES(?, ?, ?, ?)");
|
SQLitePreparedStatement state2 = database.executeFast("REPLACE INTO dialogs VALUES(?, ?, ?, ?, ?)");
|
||||||
SQLitePreparedStatement state3 = database.executeFast("REPLACE INTO media VALUES(?, ?, ?, ?)");
|
SQLitePreparedStatement state3 = database.executeFast("REPLACE INTO media VALUES(?, ?, ?, ?)");
|
||||||
|
|
||||||
for (TLRPC.TL_dialog dialog : dialogs.dialogs) {
|
for (TLRPC.TL_dialog dialog : dialogs.dialogs) {
|
||||||
@ -2915,6 +3532,10 @@ public class MessagesStorage {
|
|||||||
state2.bindInteger(2, message.date);
|
state2.bindInteger(2, message.date);
|
||||||
state2.bindInteger(3, dialog.unread_count);
|
state2.bindInteger(3, dialog.unread_count);
|
||||||
state2.bindInteger(4, dialog.top_message);
|
state2.bindInteger(4, dialog.top_message);
|
||||||
|
if (dialog.notify_settings.mute_until != 0) {
|
||||||
|
dialog.flags = 1;
|
||||||
|
}
|
||||||
|
state2.bindInteger(5, dialog.flags);
|
||||||
state2.step();
|
state2.step();
|
||||||
|
|
||||||
if (message.media instanceof TLRPC.TL_messageMediaVideo || message.media instanceof TLRPC.TL_messageMediaPhoto) {
|
if (message.media instanceof TLRPC.TL_messageMediaVideo || message.media instanceof TLRPC.TL_messageMediaPhoto) {
|
||||||
@ -2979,7 +3600,7 @@ public class MessagesStorage {
|
|||||||
|
|
||||||
database.commitTransaction();
|
database.commitTransaction();
|
||||||
|
|
||||||
loadUnreadMessages();
|
loadUnreadMessages(true);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
|
@ -6,13 +6,62 @@
|
|||||||
* Copyright Nikolai Kudashov, 2013.
|
* Copyright Nikolai Kudashov, 2013.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.telegram.messenger;
|
package org.telegram.android;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
|
||||||
public class NotificationCenter {
|
public class NotificationCenter {
|
||||||
|
|
||||||
|
public static final int didReceivedNewMessages = 1;
|
||||||
|
public static final int updateInterfaces = 3;
|
||||||
|
public static final int dialogsNeedReload = 4;
|
||||||
|
public static final int closeChats = 5;
|
||||||
|
public static final int messagesDeleted = 6;
|
||||||
|
public static final int messagesReaded = 7;
|
||||||
|
public static final int messagesDidLoaded = 8;
|
||||||
|
public static final int messageReceivedByAck = 9;
|
||||||
|
public static final int messageReceivedByServer = 10;
|
||||||
|
public static final int messageSendError = 11;
|
||||||
|
public static final int reloadSearchResults = 12;
|
||||||
|
public static final int contactsDidLoaded = 13;
|
||||||
|
public static final int chatDidCreated = 15;
|
||||||
|
public static final int chatDidFailCreate = 16;
|
||||||
|
public static final int chatInfoDidLoaded = 17;
|
||||||
|
public static final int mediaDidLoaded = 18;
|
||||||
|
public static final int mediaCountDidLoaded = 20;
|
||||||
|
public static final int encryptedChatUpdated = 21;
|
||||||
|
public static final int messagesReadedEncrypted = 22;
|
||||||
|
public static final int encryptedChatCreated = 23;
|
||||||
|
public static final int userPhotosLoaded = 24;
|
||||||
|
public static final int removeAllMessagesFromDialog = 25;
|
||||||
|
public static final int notificationsSettingsUpdated = 26;
|
||||||
|
public static final int pushMessagesUpdated = 27;
|
||||||
|
public static final int blockedUsersDidLoaded = 28;
|
||||||
|
|
||||||
|
public static final int wallpapersDidLoaded = 171;
|
||||||
|
public static final int closeOtherAppActivities = 702;
|
||||||
|
public static final int didUpdatedConnectionState = 703;
|
||||||
|
public static final int emojiDidLoaded = 999;
|
||||||
|
public static final int appDidLogout = 1234;
|
||||||
|
|
||||||
|
public static final int FileDidUpload = 10000;
|
||||||
|
public static final int FileDidFailUpload = 10001;
|
||||||
|
public static final int FileUploadProgressChanged = 10002;
|
||||||
|
public static final int FileLoadProgressChanged = 10003;
|
||||||
|
public static final int FileDidLoaded = 10004;
|
||||||
|
public static final int FileDidFailedLoad = 10005;
|
||||||
|
|
||||||
|
public final static int audioProgressDidChanged = 50001;
|
||||||
|
public final static int audioDidReset = 50002;
|
||||||
|
public final static int recordProgressChanged = 50003;
|
||||||
|
public final static int recordStarted = 50004;
|
||||||
|
public final static int recordStartError = 50005;
|
||||||
|
public final static int recordStopped = 50006;
|
||||||
|
public final static int screenshotTook = 50007;
|
||||||
|
public final static int albumsDidLoaded = 50008;
|
||||||
|
public final static int audioDidSent = 50009;
|
||||||
|
|
||||||
final private HashMap<Integer, ArrayList<Object>> observers = new HashMap<Integer, ArrayList<Object>>();
|
final private HashMap<Integer, ArrayList<Object>> observers = new HashMap<Integer, ArrayList<Object>>();
|
||||||
|
|
||||||
final private HashMap<Integer, Object> removeAfterBroadcast = new HashMap<Integer, Object>();
|
final private HashMap<Integer, Object> removeAfterBroadcast = new HashMap<Integer, Object>();
|
@ -0,0 +1,31 @@
|
|||||||
|
/*
|
||||||
|
* This is the source code of Telegram for Android v. 1.7.x.
|
||||||
|
* It is licensed under GNU GPL v. 2 or later.
|
||||||
|
* You should have received a copy of the license in this archive (see LICENSE).
|
||||||
|
*
|
||||||
|
* Copyright Nikolai Kudashov, 2013-2014.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.telegram.android;
|
||||||
|
|
||||||
|
import android.app.IntentService;
|
||||||
|
import android.content.Intent;
|
||||||
|
|
||||||
|
import org.telegram.messenger.Utilities;
|
||||||
|
|
||||||
|
public class NotificationRepeat extends IntentService {
|
||||||
|
|
||||||
|
public NotificationRepeat() {
|
||||||
|
super("NotificationRepeat");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onHandleIntent(Intent intent) {
|
||||||
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
NotificationsController.getInstance().repeatNotificationMaybe();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
@ -8,51 +8,51 @@
|
|||||||
|
|
||||||
package org.telegram.android;
|
package org.telegram.android;
|
||||||
|
|
||||||
import android.app.NotificationManager;
|
import android.app.AlarmManager;
|
||||||
import android.app.PendingIntent;
|
import android.app.PendingIntent;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.content.pm.ResolveInfo;
|
import android.content.pm.ResolveInfo;
|
||||||
import android.graphics.Bitmap;
|
import android.graphics.drawable.BitmapDrawable;
|
||||||
import android.media.AudioManager;
|
import android.media.AudioManager;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
|
import android.os.SystemClock;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
import android.support.v4.app.NotificationCompat;
|
import android.support.v4.app.NotificationCompat;
|
||||||
|
import android.support.v4.app.NotificationManagerCompat;
|
||||||
|
|
||||||
import org.json.JSONArray;
|
import org.json.JSONArray;
|
||||||
import org.json.JSONObject;
|
import org.json.JSONObject;
|
||||||
import org.telegram.messenger.ConnectionsManager;
|
import org.telegram.messenger.ConnectionsManager;
|
||||||
import org.telegram.messenger.FileLoader;
|
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.objects.MessageObject;
|
|
||||||
import org.telegram.ui.ApplicationLoader;
|
import org.telegram.ui.ApplicationLoader;
|
||||||
import org.telegram.ui.LaunchActivity;
|
import org.telegram.ui.LaunchActivity;
|
||||||
import org.telegram.ui.PopupNotificationActivity;
|
import org.telegram.ui.PopupNotificationActivity;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Calendar;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class NotificationsController {
|
public class NotificationsController {
|
||||||
|
|
||||||
|
public static final String EXTRA_VOICE_REPLY = "extra_voice_reply";
|
||||||
|
|
||||||
private ArrayList<MessageObject> pushMessages = new ArrayList<MessageObject>();
|
private ArrayList<MessageObject> pushMessages = new ArrayList<MessageObject>();
|
||||||
private HashMap<Integer, MessageObject> pushMessagesDict = new HashMap<Integer, MessageObject>();
|
private HashMap<Integer, MessageObject> pushMessagesDict = new HashMap<Integer, MessageObject>();
|
||||||
private NotificationManager notificationManager = null;
|
private NotificationManagerCompat notificationManager = null;
|
||||||
private HashMap<Long, Integer> pushDialogs = new HashMap<Long, Integer>();
|
private HashMap<Long, Integer> pushDialogs = new HashMap<Long, Integer>();
|
||||||
public ArrayList<MessageObject> popupMessages = new ArrayList<MessageObject>();
|
public ArrayList<MessageObject> popupMessages = new ArrayList<MessageObject>();
|
||||||
private long openned_dialog_id = 0;
|
private long openned_dialog_id = 0;
|
||||||
private int total_unread_count = 0;
|
private int total_unread_count = 0;
|
||||||
private boolean notifyCheck = false;
|
private boolean notifyCheck = false;
|
||||||
|
|
||||||
public static final int pushMessagesUpdated = 27;
|
|
||||||
|
|
||||||
private static volatile NotificationsController Instance = null;
|
private static volatile NotificationsController Instance = null;
|
||||||
public static NotificationsController getInstance() {
|
public static NotificationsController getInstance() {
|
||||||
NotificationsController localInstance = Instance;
|
NotificationsController localInstance = Instance;
|
||||||
@ -68,7 +68,7 @@ public class NotificationsController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public NotificationsController() {
|
public NotificationsController() {
|
||||||
notificationManager = (NotificationManager)ApplicationLoader.applicationContext.getSystemService(Context.NOTIFICATION_SERVICE);
|
notificationManager = NotificationManagerCompat.from(ApplicationLoader.applicationContext);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void cleanup() {
|
public void cleanup() {
|
||||||
@ -79,6 +79,10 @@ public class NotificationsController {
|
|||||||
pushDialogs.clear();
|
pushDialogs.clear();
|
||||||
popupMessages.clear();
|
popupMessages.clear();
|
||||||
notifyCheck = false;
|
notifyCheck = false;
|
||||||
|
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("Notifications", Context.MODE_PRIVATE);
|
||||||
|
SharedPreferences.Editor editor = preferences.edit();
|
||||||
|
editor.clear();
|
||||||
|
editor.commit();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setOpennedDialogId(long dialog_id) {
|
public void setOpennedDialogId(long dialog_id) {
|
||||||
@ -103,13 +107,13 @@ public class NotificationsController {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(user_id);
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
TLRPC.Chat chat = null;
|
TLRPC.Chat chat = null;
|
||||||
if (chat_id != 0) {
|
if (chat_id != 0) {
|
||||||
chat = MessagesController.getInstance().chats.get(chat_id);
|
chat = MessagesController.getInstance().getChat(chat_id);
|
||||||
if (chat == null) {
|
if (chat == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -161,7 +165,7 @@ public class NotificationsController {
|
|||||||
if (messageObject.messageOwner.action.user_id == UserConfig.getClientUserId()) {
|
if (messageObject.messageOwner.action.user_id == UserConfig.getClientUserId()) {
|
||||||
msg = LocaleController.formatString("NotificationInvitedToGroup", R.string.NotificationInvitedToGroup, Utilities.formatName(user.first_name, user.last_name), chat.title);
|
msg = LocaleController.formatString("NotificationInvitedToGroup", R.string.NotificationInvitedToGroup, Utilities.formatName(user.first_name, user.last_name), chat.title);
|
||||||
} else {
|
} else {
|
||||||
TLRPC.User u2 = MessagesController.getInstance().users.get(messageObject.messageOwner.action.user_id);
|
TLRPC.User u2 = MessagesController.getInstance().getUser(messageObject.messageOwner.action.user_id);
|
||||||
if (u2 == null) {
|
if (u2 == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -177,7 +181,7 @@ public class NotificationsController {
|
|||||||
} else if (messageObject.messageOwner.action.user_id == user.id) {
|
} else if (messageObject.messageOwner.action.user_id == user.id) {
|
||||||
msg = LocaleController.formatString("NotificationGroupLeftMember", R.string.NotificationGroupLeftMember, Utilities.formatName(user.first_name, user.last_name), chat.title);
|
msg = LocaleController.formatString("NotificationGroupLeftMember", R.string.NotificationGroupLeftMember, Utilities.formatName(user.first_name, user.last_name), chat.title);
|
||||||
} else {
|
} else {
|
||||||
TLRPC.User u2 = MessagesController.getInstance().users.get(messageObject.messageOwner.action.user_id);
|
TLRPC.User u2 = MessagesController.getInstance().getUser(messageObject.messageOwner.action.user_id);
|
||||||
if (u2 == null) {
|
if (u2 == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -217,6 +221,22 @@ public class NotificationsController {
|
|||||||
return msg;
|
return msg;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void scheduleNotificationRepeat() {
|
||||||
|
PendingIntent pintent = PendingIntent.getService(ApplicationLoader.applicationContext, 0, new Intent(ApplicationLoader.applicationContext, NotificationRepeat.class), 0);
|
||||||
|
AlarmManager alarm = (AlarmManager) ApplicationLoader.applicationContext.getSystemService(Context.ALARM_SERVICE);
|
||||||
|
alarm.set(AlarmManager.ELAPSED_REALTIME_WAKEUP, SystemClock.elapsedRealtime() + 60 * 60 * 1000, pintent);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void repeatNotificationMaybe() {
|
||||||
|
int hour = Calendar.getInstance().get(Calendar.HOUR_OF_DAY);
|
||||||
|
if (hour >= 11 && hour <= 22) {
|
||||||
|
notificationManager.cancel(1);
|
||||||
|
showOrUpdateNotification(true);
|
||||||
|
} else {
|
||||||
|
scheduleNotificationRepeat();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void showOrUpdateNotification(boolean notifyAboutLast) {
|
private void showOrUpdateNotification(boolean notifyAboutLast) {
|
||||||
if (!UserConfig.isClientActivated() || pushMessages.isEmpty()) {
|
if (!UserConfig.isClientActivated() || pushMessages.isEmpty()) {
|
||||||
dismissNotification();
|
dismissNotification();
|
||||||
@ -236,15 +256,15 @@ public class NotificationsController {
|
|||||||
user_id = lastMessageObject.messageOwner.from_id;
|
user_id = lastMessageObject.messageOwner.from_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(user_id);
|
||||||
TLRPC.Chat chat = null;
|
TLRPC.Chat chat = null;
|
||||||
if (chat_id != 0) {
|
if (chat_id != 0) {
|
||||||
chat = MessagesController.getInstance().chats.get(chat_id);
|
chat = MessagesController.getInstance().getChat(chat_id);
|
||||||
}
|
}
|
||||||
TLRPC.FileLocation photoPath = null;
|
TLRPC.FileLocation photoPath = null;
|
||||||
|
|
||||||
boolean notifyDisabled = false;
|
boolean notifyDisabled = false;
|
||||||
boolean needVibrate = false;
|
int needVibrate = 0;
|
||||||
String choosenSoundPath = null;
|
String choosenSoundPath = null;
|
||||||
int ledColor = 0xff00ff00;
|
int ledColor = 0xff00ff00;
|
||||||
boolean inAppSounds = false;
|
boolean inAppSounds = false;
|
||||||
@ -265,7 +285,6 @@ public class NotificationsController {
|
|||||||
inAppPreview = preferences.getBoolean("EnableInAppPreview", true);
|
inAppPreview = preferences.getBoolean("EnableInAppPreview", true);
|
||||||
vibrate_override = preferences.getInt("vibrate_" + dialog_id, 0);
|
vibrate_override = preferences.getInt("vibrate_" + dialog_id, 0);
|
||||||
|
|
||||||
|
|
||||||
choosenSoundPath = preferences.getString("sound_path_" + dialog_id, null);
|
choosenSoundPath = preferences.getString("sound_path_" + dialog_id, null);
|
||||||
if (chat_id != 0) {
|
if (chat_id != 0) {
|
||||||
if (choosenSoundPath != null && choosenSoundPath.equals(defaultPath)) {
|
if (choosenSoundPath != null && choosenSoundPath.equals(defaultPath)) {
|
||||||
@ -273,7 +292,7 @@ public class NotificationsController {
|
|||||||
} else if (choosenSoundPath == null) {
|
} else if (choosenSoundPath == null) {
|
||||||
choosenSoundPath = preferences.getString("GroupSoundPath", defaultPath);
|
choosenSoundPath = preferences.getString("GroupSoundPath", defaultPath);
|
||||||
}
|
}
|
||||||
needVibrate = preferences.getBoolean("EnableVibrateGroup", true);
|
needVibrate = preferences.getInt("vibrate_group", 0);
|
||||||
ledColor = preferences.getInt("GroupLed", 0xff00ff00);
|
ledColor = preferences.getInt("GroupLed", 0xff00ff00);
|
||||||
} else if (user_id != 0) {
|
} else if (user_id != 0) {
|
||||||
if (choosenSoundPath != null && choosenSoundPath.equals(defaultPath)) {
|
if (choosenSoundPath != null && choosenSoundPath.equals(defaultPath)) {
|
||||||
@ -281,24 +300,22 @@ public class NotificationsController {
|
|||||||
} else if (choosenSoundPath == null) {
|
} else if (choosenSoundPath == null) {
|
||||||
choosenSoundPath = preferences.getString("GlobalSoundPath", defaultPath);
|
choosenSoundPath = preferences.getString("GlobalSoundPath", defaultPath);
|
||||||
}
|
}
|
||||||
needVibrate = preferences.getBoolean("EnableVibrateAll", true);
|
needVibrate = preferences.getInt("vibrate_messages", 0);
|
||||||
ledColor = preferences.getInt("MessagesLed", 0xff00ff00);
|
ledColor = preferences.getInt("MessagesLed", 0xff00ff00);
|
||||||
}
|
}
|
||||||
if (preferences.contains("color_" + dialog_id)) {
|
if (preferences.contains("color_" + dialog_id)) {
|
||||||
ledColor = preferences.getInt("color_" + dialog_id, 0);
|
ledColor = preferences.getInt("color_" + dialog_id, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!needVibrate && vibrate_override == 1) {
|
if (needVibrate == 2 && (vibrate_override == 1 || vibrate_override == 3 || vibrate_override == 5) || needVibrate != 2 && vibrate_override == 2 || vibrate_override != 0) {
|
||||||
needVibrate = true;
|
needVibrate = vibrate_override;
|
||||||
} else if (needVibrate && vibrate_override == 2) {
|
|
||||||
needVibrate = false;
|
|
||||||
}
|
}
|
||||||
if (!ApplicationLoader.mainInterfacePaused) {
|
if (!ApplicationLoader.mainInterfacePaused) {
|
||||||
if (!inAppSounds) {
|
if (!inAppSounds) {
|
||||||
choosenSoundPath = null;
|
choosenSoundPath = null;
|
||||||
}
|
}
|
||||||
if (!inAppVibrate) {
|
if (!inAppVibrate) {
|
||||||
needVibrate = false;
|
needVibrate = 2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -402,9 +419,9 @@ public class NotificationsController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (photoPath != null) {
|
if (photoPath != null) {
|
||||||
Bitmap img = FileLoader.getInstance().getImageFromMemory(photoPath, null, null, "50_50");
|
BitmapDrawable img = ImageLoader.getInstance().getImageFromMemory(photoPath, null, "50_50");
|
||||||
if (img != null) {
|
if (img != null) {
|
||||||
mBuilder.setLargeIcon(img);
|
mBuilder.setLargeIcon(img.getBitmap());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -422,19 +439,26 @@ public class NotificationsController {
|
|||||||
if (ledColor != 0) {
|
if (ledColor != 0) {
|
||||||
mBuilder.setLights(ledColor, 1000, 1000);
|
mBuilder.setLights(ledColor, 1000, 1000);
|
||||||
}
|
}
|
||||||
if (needVibrate) {
|
if (needVibrate == 2) {
|
||||||
mBuilder.setVibrate(new long[]{0, 100, 0, 100});
|
|
||||||
} else {
|
|
||||||
mBuilder.setVibrate(new long[]{0, 0});
|
mBuilder.setVibrate(new long[]{0, 0});
|
||||||
|
} else if (needVibrate == 1) {
|
||||||
|
mBuilder.setVibrate(new long[]{0, 100, 0, 100});
|
||||||
|
} else if (needVibrate == 0 || needVibrate == 5) {
|
||||||
|
mBuilder.setDefaults(NotificationCompat.DEFAULT_VIBRATE);
|
||||||
|
} else if (needVibrate == 3) {
|
||||||
|
mBuilder.setVibrate(new long[]{0, 300, 100, 300});
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
mBuilder.setVibrate(new long[]{0, 0});
|
mBuilder.setVibrate(new long[]{0, 0});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//RemoteInput remoteInput = new RemoteInput.Builder(EXTRA_VOICE_REPLY).setLabel(LocaleController.getString("Reply", R.string.Reply)).build();
|
||||||
|
|
||||||
notificationManager.notify(1, mBuilder.build());
|
notificationManager.notify(1, mBuilder.build());
|
||||||
if (preferences.getBoolean("EnablePebbleNotifications", false)) {
|
if (preferences.getBoolean("EnablePebbleNotifications", false)) {
|
||||||
sendAlertToPebble(lastMessage);
|
sendAlertToPebble(lastMessage);
|
||||||
}
|
}
|
||||||
|
scheduleNotificationRepeat();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
@ -445,7 +469,7 @@ public class NotificationsController {
|
|||||||
notificationManager.cancel(1);
|
notificationManager.cancel(1);
|
||||||
pushMessages.clear();
|
pushMessages.clear();
|
||||||
pushMessagesDict.clear();
|
pushMessagesDict.clear();
|
||||||
NotificationCenter.getInstance().postNotificationName(pushMessagesUpdated);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.pushMessagesUpdated);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
@ -471,7 +495,7 @@ public class NotificationsController {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void processReadMessages(ArrayList<Integer> readMessages, long dialog_id, int max_date, int max_id) {
|
public void processReadMessages(ArrayList<Integer> readMessages, long dialog_id, int max_date, int max_id, boolean isPopup) {
|
||||||
int oldCount = popupMessages.size();
|
int oldCount = popupMessages.size();
|
||||||
int oldCount2 = pushMessages.size();
|
int oldCount2 = pushMessages.size();
|
||||||
if (readMessages != null) {
|
if (readMessages != null) {
|
||||||
@ -494,9 +518,15 @@ public class NotificationsController {
|
|||||||
remove = true;
|
remove = true;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
if (!isPopup) {
|
||||||
if (messageObject.messageOwner.id <= max_id || max_id < 0) {
|
if (messageObject.messageOwner.id <= max_id || max_id < 0) {
|
||||||
remove = true;
|
remove = true;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
if (messageObject.messageOwner.id == max_id || max_id < 0) {
|
||||||
|
remove = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (remove) {
|
if (remove) {
|
||||||
pushMessages.remove(a);
|
pushMessages.remove(a);
|
||||||
@ -508,7 +538,7 @@ public class NotificationsController {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (oldCount != popupMessages.size()) {
|
if (oldCount != popupMessages.size()) {
|
||||||
NotificationCenter.getInstance().postNotificationName(pushMessagesUpdated);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.pushMessagesUpdated);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -578,7 +608,10 @@ public class NotificationsController {
|
|||||||
boolean canAddValue = !(notify_override == 2 || (!preferences.getBoolean("EnableAll", true) || isChat && !preferences.getBoolean("EnableGroup", true)) && notify_override == 0);
|
boolean canAddValue = !(notify_override == 2 || (!preferences.getBoolean("EnableAll", true) || isChat && !preferences.getBoolean("EnableGroup", true)) && notify_override == 0);
|
||||||
|
|
||||||
Integer newCount = entry.getValue();
|
Integer newCount = entry.getValue();
|
||||||
if (replace) {
|
if (replace || newCount < 0) {
|
||||||
|
if (newCount < 0) {
|
||||||
|
newCount *= -1;
|
||||||
|
}
|
||||||
if (currentCount != null) {
|
if (currentCount != null) {
|
||||||
total_unread_count -= currentCount;
|
total_unread_count -= currentCount;
|
||||||
}
|
}
|
||||||
@ -598,6 +631,9 @@ public class NotificationsController {
|
|||||||
pushDialogs.put(dialog_id, newCount);
|
pushDialogs.put(dialog_id, newCount);
|
||||||
}
|
}
|
||||||
} else if (canAddValue) {
|
} else if (canAddValue) {
|
||||||
|
if (newCount > 2000000) {
|
||||||
|
newCount = 2000000 - newCount;
|
||||||
|
}
|
||||||
if (currentCount == null) {
|
if (currentCount == null) {
|
||||||
currentCount = 0;
|
currentCount = 0;
|
||||||
}
|
}
|
||||||
@ -615,25 +651,39 @@ public class NotificationsController {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void processLoadedUnreadMessages(HashMap<Long, Integer> dialogs) {
|
public void processLoadedUnreadMessages(HashMap<Long, Integer> dialogs, ArrayList<TLRPC.Message> messages, ArrayList<TLRPC.User> users, ArrayList<TLRPC.Chat> chats, ArrayList<TLRPC.EncryptedChat> encryptedChats) {
|
||||||
|
MessagesController.getInstance().putUsers(users, true);
|
||||||
|
MessagesController.getInstance().putChats(chats, true);
|
||||||
|
MessagesController.getInstance().putEncryptedChats(encryptedChats, true);
|
||||||
|
|
||||||
|
if (messages != null) {
|
||||||
|
for (TLRPC.Message message : messages) {
|
||||||
|
if (pushMessagesDict.containsKey(message.id)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
MessageObject messageObject = new MessageObject(message, null, 0);
|
||||||
|
long dialog_id = messageObject.getDialogId();
|
||||||
|
if (dialog_id == openned_dialog_id && ApplicationLoader.isScreenOn) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
pushMessagesDict.put(messageObject.messageOwner.id, messageObject);
|
||||||
|
pushMessages.add(0, messageObject);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pushDialogs.clear();
|
pushDialogs.clear();
|
||||||
total_unread_count = 0;
|
total_unread_count = 0;
|
||||||
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("Notifications", Context.MODE_PRIVATE);
|
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("Notifications", Context.MODE_PRIVATE);
|
||||||
for (HashMap.Entry<Long, Integer> entry : dialogs.entrySet()) {
|
for (HashMap.Entry<Long, Integer> entry : dialogs.entrySet()) {
|
||||||
long dialog_id = entry.getKey();
|
pushDialogs.put(entry.getKey(), entry.getValue());
|
||||||
int notify_override = preferences.getInt("notify2_" + dialog_id, 0);
|
|
||||||
boolean isChat = (int)dialog_id < 0;
|
|
||||||
if (!(notify_override == 2 || (!preferences.getBoolean("EnableAll", true) || isChat && !preferences.getBoolean("EnableGroup", true)) && notify_override == 0)) {
|
|
||||||
pushDialogs.put(dialog_id, entry.getValue());
|
|
||||||
total_unread_count += entry.getValue();
|
total_unread_count += entry.getValue();
|
||||||
}
|
}
|
||||||
}
|
|
||||||
if (total_unread_count == 0) {
|
if (total_unread_count == 0) {
|
||||||
pushMessages.clear();
|
pushMessages.clear();
|
||||||
pushMessagesDict.clear();
|
pushMessagesDict.clear();
|
||||||
popupMessages.clear();
|
popupMessages.clear();
|
||||||
showOrUpdateNotification(false);
|
showOrUpdateNotification(false);
|
||||||
NotificationCenter.getInstance().postNotificationName(pushMessagesUpdated);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.pushMessagesUpdated);
|
||||||
}
|
}
|
||||||
if (preferences.getBoolean("badgeNumber", true)) {
|
if (preferences.getBoolean("badgeNumber", true)) {
|
||||||
setBadge(ApplicationLoader.applicationContext, total_unread_count);
|
setBadge(ApplicationLoader.applicationContext, total_unread_count);
|
||||||
|
@ -6,13 +6,12 @@
|
|||||||
* Copyright Nikolai Kudashov, 2013.
|
* Copyright Nikolai Kudashov, 2013.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.telegram.objects;
|
package org.telegram.android;
|
||||||
|
|
||||||
import android.graphics.Bitmap;
|
import android.graphics.Bitmap;
|
||||||
import android.graphics.BitmapFactory;
|
import android.graphics.BitmapFactory;
|
||||||
|
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.messenger.FileLoader;
|
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
@ -35,8 +34,8 @@ public class PhotoObject {
|
|||||||
if (preview == 2) {
|
if (preview == 2) {
|
||||||
Utilities.blurBitmap(image, image.getWidth(), image.getHeight(), image.getRowBytes());
|
Utilities.blurBitmap(image, image.getWidth(), image.getHeight(), image.getRowBytes());
|
||||||
}
|
}
|
||||||
if (FileLoader.getInstance().runtimeHack != null) {
|
if (ImageLoader.getInstance().runtimeHack != null) {
|
||||||
FileLoader.getInstance().runtimeHack.trackFree(image.getRowBytes() * image.getHeight());
|
ImageLoader.getInstance().runtimeHack.trackFree(image.getRowBytes() * image.getHeight());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
File diff suppressed because it is too large
Load Diff
@ -16,7 +16,6 @@ import android.os.Bundle;
|
|||||||
import android.telephony.SmsMessage;
|
import android.telephony.SmsMessage;
|
||||||
|
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
|
||||||
|
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
@ -17,8 +17,10 @@ import android.os.Build;
|
|||||||
import android.os.PowerManager;
|
import android.os.PowerManager;
|
||||||
import android.util.Base64;
|
import android.util.Base64;
|
||||||
|
|
||||||
|
import org.telegram.android.AndroidUtilities;
|
||||||
import org.telegram.android.ContactsController;
|
import org.telegram.android.ContactsController;
|
||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.ui.ApplicationLoader;
|
import org.telegram.ui.ApplicationLoader;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
@ -456,7 +458,7 @@ public class ConnectionsManager implements Action.ActionDelegate, TcpConnection.
|
|||||||
|
|
||||||
datacenter = new Datacenter();
|
datacenter = new Datacenter();
|
||||||
datacenter.datacenterId = 5;
|
datacenter.datacenterId = 5;
|
||||||
datacenter.addAddressAndPort("116.51.22.2", 443);
|
datacenter.addAddressAndPort("149.154.171.5", 443);
|
||||||
datacenters.put(datacenter.datacenterId, datacenter);
|
datacenters.put(datacenter.datacenterId, datacenter);
|
||||||
} else {
|
} else {
|
||||||
Datacenter datacenter = new Datacenter();
|
Datacenter datacenter = new Datacenter();
|
||||||
@ -643,7 +645,7 @@ public class ConnectionsManager implements Action.ActionDelegate, TcpConnection.
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void bindRequestToGuid(final Long request, final int guid) {
|
public void bindRequestToGuid(final Long request, final int guid) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
ArrayList<Long> requests = requestsByGuids.get(guid);
|
ArrayList<Long> requests = requestsByGuids.get(guid);
|
||||||
@ -656,7 +658,7 @@ public class ConnectionsManager implements Action.ActionDelegate, TcpConnection.
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void removeRequestInClass(final Long request) {
|
public void removeRequestInClass(final Long request) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
Integer guid = requestsByClass.get(request);
|
Integer guid = requestsByClass.get(request);
|
||||||
@ -964,6 +966,19 @@ public class ConnectionsManager implements Action.ActionDelegate, TcpConnection.
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static boolean isRoaming() {
|
||||||
|
try {
|
||||||
|
ConnectivityManager cm = (ConnectivityManager)ApplicationLoader.applicationContext.getSystemService(Context.CONNECTIVITY_SERVICE);
|
||||||
|
NetworkInfo netInfo = cm.getActiveNetworkInfo();
|
||||||
|
if (netInfo != null) {
|
||||||
|
return netInfo.isRoaming();
|
||||||
|
}
|
||||||
|
} catch(Exception e) {
|
||||||
|
FileLog.e("tmessages", e);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public static boolean isConnectedToWiFi() {
|
public static boolean isConnectedToWiFi() {
|
||||||
try {
|
try {
|
||||||
ConnectivityManager cm = (ConnectivityManager)ApplicationLoader.applicationContext.getSystemService(Context.CONNECTIVITY_SERVICE);
|
ConnectivityManager cm = (ConnectivityManager)ApplicationLoader.applicationContext.getSystemService(Context.CONNECTIVITY_SERVICE);
|
||||||
@ -2094,7 +2109,7 @@ public class ConnectionsManager implements Action.ActionDelegate, TcpConnection.
|
|||||||
} else {
|
} else {
|
||||||
if (resultContainer.result instanceof TLRPC.updates_Difference) {
|
if (resultContainer.result instanceof TLRPC.updates_Difference) {
|
||||||
pushMessagesReceived = true;
|
pushMessagesReceived = true;
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
if (wakeLock.isHeld()) {
|
if (wakeLock.isHeld()) {
|
||||||
@ -2113,10 +2128,10 @@ public class ConnectionsManager implements Action.ActionDelegate, TcpConnection.
|
|||||||
if ((request.flags & RPCRequest.RPCRequestClassGeneric) != 0) {
|
if ((request.flags & RPCRequest.RPCRequestClassGeneric) != 0) {
|
||||||
if (UserConfig.isClientActivated()) {
|
if (UserConfig.isClientActivated()) {
|
||||||
UserConfig.clearConfig();
|
UserConfig.clearConfig();
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
NotificationCenter.getInstance().postNotificationName(1234);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.appDidLogout);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -2272,7 +2287,7 @@ public class ConnectionsManager implements Action.ActionDelegate, TcpConnection.
|
|||||||
if (paused) {
|
if (paused) {
|
||||||
pushMessagesReceived = false;
|
pushMessagesReceived = false;
|
||||||
}
|
}
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
wakeLock.acquire(20000);
|
wakeLock.acquire(20000);
|
||||||
@ -2281,7 +2296,7 @@ public class ConnectionsManager implements Action.ActionDelegate, TcpConnection.
|
|||||||
resumeNetworkInternal();
|
resumeNetworkInternal();
|
||||||
} else {
|
} else {
|
||||||
pushMessagesReceived = true;
|
pushMessagesReceived = true;
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
if (wakeLock.isHeld()) {
|
if (wakeLock.isHeld()) {
|
||||||
@ -2386,10 +2401,10 @@ public class ConnectionsManager implements Action.ActionDelegate, TcpConnection.
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
final int stateCopy = connectionState;
|
final int stateCopy = connectionState;
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
NotificationCenter.getInstance().postNotificationName(703, stateCopy);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.didUpdatedConnectionState, stateCopy);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
} else if ((connection.transportRequestClass & RPCRequest.RPCRequestClassPush) != 0) {
|
} else if ((connection.transportRequestClass & RPCRequest.RPCRequestClassPush) != 0) {
|
||||||
@ -2435,10 +2450,10 @@ public class ConnectionsManager implements Action.ActionDelegate, TcpConnection.
|
|||||||
if (ConnectionsManager.getInstance().connectionState == 3 && !MessagesController.getInstance().gettingDifference && !MessagesController.getInstance().gettingDifferenceAgain) {
|
if (ConnectionsManager.getInstance().connectionState == 3 && !MessagesController.getInstance().gettingDifference && !MessagesController.getInstance().gettingDifferenceAgain) {
|
||||||
ConnectionsManager.getInstance().connectionState = 0;
|
ConnectionsManager.getInstance().connectionState = 0;
|
||||||
final int stateCopy = ConnectionsManager.getInstance().connectionState;
|
final int stateCopy = ConnectionsManager.getInstance().connectionState;
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
NotificationCenter.getInstance().postNotificationName(703, stateCopy);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.didUpdatedConnectionState, stateCopy);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -2451,10 +2466,10 @@ public class ConnectionsManager implements Action.ActionDelegate, TcpConnection.
|
|||||||
if (connectionState == 1 || connectionState == 2) {
|
if (connectionState == 1 || connectionState == 2) {
|
||||||
connectionState = 3;
|
connectionState = 3;
|
||||||
final int stateCopy = connectionState;
|
final int stateCopy = connectionState;
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
NotificationCenter.getInstance().postNotificationName(703, stateCopy);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.didUpdatedConnectionState, stateCopy);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -8,20 +8,8 @@
|
|||||||
|
|
||||||
package org.telegram.messenger;
|
package org.telegram.messenger;
|
||||||
|
|
||||||
import android.graphics.Bitmap;
|
|
||||||
import android.graphics.BitmapFactory;
|
|
||||||
import android.os.AsyncTask;
|
|
||||||
import android.provider.MediaStore;
|
|
||||||
|
|
||||||
import org.telegram.android.AndroidUtilities;
|
|
||||||
import org.telegram.ui.ApplicationLoader;
|
|
||||||
|
|
||||||
import java.io.RandomAccessFile;
|
import java.io.RandomAccessFile;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileInputStream;
|
|
||||||
import java.io.InputStream;
|
|
||||||
import java.net.URL;
|
|
||||||
import java.net.URLConnection;
|
|
||||||
import java.nio.channels.FileChannel;
|
import java.nio.channels.FileChannel;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Scanner;
|
import java.util.Scanner;
|
||||||
@ -34,17 +22,20 @@ public class FileLoadOperation {
|
|||||||
private TLRPC.TL_upload_file response = null;
|
private TLRPC.TL_upload_file response = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private final static int stateIdle = 0;
|
||||||
|
private final static int stateDownloading = 1;
|
||||||
|
private final static int stateFailed = 2;
|
||||||
|
private final static int stateFinished = 3;
|
||||||
|
|
||||||
private final static int downloadChunkSize = 1024 * 32;
|
private final static int downloadChunkSize = 1024 * 32;
|
||||||
private final static int maxDownloadRequests = 3;
|
private final static int maxDownloadRequests = 3;
|
||||||
|
|
||||||
public int datacenter_id;
|
private int datacenter_id;
|
||||||
public TLRPC.InputFileLocation location;
|
private TLRPC.InputFileLocation location;
|
||||||
public volatile int state = 0;
|
private volatile int state = stateIdle;
|
||||||
private int downloadedBytes;
|
private int downloadedBytes;
|
||||||
public int totalBytesCount;
|
private int totalBytesCount;
|
||||||
public FileLoadOperationDelegate delegate;
|
private FileLoadOperationDelegate delegate;
|
||||||
public Bitmap image;
|
|
||||||
public String filter;
|
|
||||||
private byte[] key;
|
private byte[] key;
|
||||||
private byte[] iv;
|
private byte[] iv;
|
||||||
|
|
||||||
@ -57,139 +48,34 @@ public class FileLoadOperation {
|
|||||||
private File cacheIvTemp;
|
private File cacheIvTemp;
|
||||||
|
|
||||||
private String ext;
|
private String ext;
|
||||||
private String httpUrl;
|
|
||||||
private DownloadImageTask httpTask = null;
|
|
||||||
public boolean needBitmapCreate = true;
|
|
||||||
private RandomAccessFile fileOutputStream;
|
private RandomAccessFile fileOutputStream;
|
||||||
private RandomAccessFile fiv;
|
private RandomAccessFile fiv;
|
||||||
|
|
||||||
public static interface FileLoadOperationDelegate {
|
public static interface FileLoadOperationDelegate {
|
||||||
public abstract void didFinishLoadingFile(FileLoadOperation operation);
|
public abstract void didFinishLoadingFile(FileLoadOperation operation, File finalFile, File tempFile);
|
||||||
public abstract void didFailedLoadingFile(FileLoadOperation operation);
|
public abstract void didFailedLoadingFile(FileLoadOperation operation, boolean canceled);
|
||||||
public abstract void didChangedLoadProgress(FileLoadOperation operation, float progress);
|
public abstract void didChangedLoadProgress(FileLoadOperation operation, float progress);
|
||||||
}
|
}
|
||||||
|
|
||||||
private class DownloadImageTask extends AsyncTask<String, Void, Boolean> {
|
public FileLoadOperation(TLRPC.FileLocation photoLocation, int size) {
|
||||||
protected Boolean doInBackground(String... urls) {
|
if (photoLocation instanceof TLRPC.TL_fileEncryptedLocation) {
|
||||||
String url = urls[0];
|
|
||||||
|
|
||||||
InputStream httpConnectionStream = null;
|
|
||||||
|
|
||||||
try {
|
|
||||||
URL downloadUrl = new URL(url);
|
|
||||||
URLConnection httpConnection = downloadUrl.openConnection();
|
|
||||||
httpConnection.setConnectTimeout(5000);
|
|
||||||
httpConnection.setReadTimeout(5000);
|
|
||||||
httpConnection.connect();
|
|
||||||
httpConnectionStream = httpConnection.getInputStream();
|
|
||||||
/*String ALLOWED_URI_CHARS = "@#&=*+-_.,:!?()/~'%";
|
|
||||||
String str = Uri.encode(url, ALLOWED_URI_CHARS);
|
|
||||||
HttpClient httpclient = new DefaultHttpClient();
|
|
||||||
HttpGet request = new HttpGet(str);
|
|
||||||
|
|
||||||
httpConnectionStream = httpclient.execute(request).getEntity().getContent();*/
|
|
||||||
} catch (Exception e) {
|
|
||||||
FileLog.e("tmessages", e);
|
|
||||||
cleanup();
|
|
||||||
Utilities.stageQueue.postRunnable(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
delegate.didFailedLoadingFile(FileLoadOperation.this);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
byte[] data = new byte[1024 * 2];
|
|
||||||
while (true) {
|
|
||||||
if (isCancelled()) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
int readed = httpConnectionStream.read(data);
|
|
||||||
if (readed > 0) {
|
|
||||||
fileOutputStream.write(data, 0, readed);
|
|
||||||
} else if (readed == -1) {
|
|
||||||
FileLoader.fileLoaderQueue.postRunnable(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
cleanup();
|
|
||||||
Utilities.stageQueue.postRunnable(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
try {
|
|
||||||
onFinishLoadingFile();
|
|
||||||
} catch (Exception e) {
|
|
||||||
delegate.didFailedLoadingFile(FileLoadOperation.this);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
break;
|
|
||||||
} else {
|
|
||||||
FileLoader.fileLoaderQueue.postRunnable(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
cleanup();
|
|
||||||
Utilities.stageQueue.postRunnable(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
delegate.didFailedLoadingFile(FileLoadOperation.this);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
} catch (Exception e) {
|
|
||||||
FileLog.e("tmessages", e);
|
|
||||||
FileLoader.fileLoaderQueue.postRunnable(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
cleanup();
|
|
||||||
Utilities.stageQueue.postRunnable(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
delegate.didFailedLoadingFile(FileLoadOperation.this);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
|
||||||
if (httpConnectionStream != null) {
|
|
||||||
httpConnectionStream.close();
|
|
||||||
}
|
|
||||||
httpConnectionStream = null;
|
|
||||||
} catch (Exception e) {
|
|
||||||
FileLog.e("tmessages", e);
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public FileLoadOperation(TLRPC.FileLocation fileLocation) {
|
|
||||||
if (fileLocation instanceof TLRPC.TL_fileEncryptedLocation) {
|
|
||||||
location = new TLRPC.TL_inputEncryptedFileLocation();
|
location = new TLRPC.TL_inputEncryptedFileLocation();
|
||||||
location.id = fileLocation.volume_id;
|
location.id = photoLocation.volume_id;
|
||||||
location.volume_id = fileLocation.volume_id;
|
location.volume_id = photoLocation.volume_id;
|
||||||
location.access_hash = fileLocation.secret;
|
location.access_hash = photoLocation.secret;
|
||||||
location.local_id = fileLocation.local_id;
|
location.local_id = photoLocation.local_id;
|
||||||
iv = new byte[32];
|
iv = new byte[32];
|
||||||
System.arraycopy(fileLocation.iv, 0, iv, 0, iv.length);
|
System.arraycopy(photoLocation.iv, 0, iv, 0, iv.length);
|
||||||
key = fileLocation.key;
|
key = photoLocation.key;
|
||||||
datacenter_id = fileLocation.dc_id;
|
datacenter_id = photoLocation.dc_id;
|
||||||
} else if (fileLocation instanceof TLRPC.TL_fileLocation) {
|
} else if (photoLocation instanceof TLRPC.TL_fileLocation) {
|
||||||
location = new TLRPC.TL_inputFileLocation();
|
location = new TLRPC.TL_inputFileLocation();
|
||||||
location.volume_id = fileLocation.volume_id;
|
location.volume_id = photoLocation.volume_id;
|
||||||
location.secret = fileLocation.secret;
|
location.secret = photoLocation.secret;
|
||||||
location.local_id = fileLocation.local_id;
|
location.local_id = photoLocation.local_id;
|
||||||
datacenter_id = fileLocation.dc_id;
|
datacenter_id = photoLocation.dc_id;
|
||||||
}
|
}
|
||||||
|
totalBytesCount = size;
|
||||||
}
|
}
|
||||||
|
|
||||||
public FileLoadOperation(TLRPC.Video videoLocation) {
|
public FileLoadOperation(TLRPC.Video videoLocation) {
|
||||||
@ -207,6 +93,7 @@ public class FileLoadOperation {
|
|||||||
location.id = videoLocation.id;
|
location.id = videoLocation.id;
|
||||||
location.access_hash = videoLocation.access_hash;
|
location.access_hash = videoLocation.access_hash;
|
||||||
}
|
}
|
||||||
|
totalBytesCount = videoLocation.size;
|
||||||
ext = ".mp4";
|
ext = ".mp4";
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -225,6 +112,7 @@ public class FileLoadOperation {
|
|||||||
location.id = audioLocation.id;
|
location.id = audioLocation.id;
|
||||||
location.access_hash = audioLocation.access_hash;
|
location.access_hash = audioLocation.access_hash;
|
||||||
}
|
}
|
||||||
|
totalBytesCount = audioLocation.size;
|
||||||
ext = ".m4a";
|
ext = ".m4a";
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -243,6 +131,7 @@ public class FileLoadOperation {
|
|||||||
location.id = documentLocation.id;
|
location.id = documentLocation.id;
|
||||||
location.access_hash = documentLocation.access_hash;
|
location.access_hash = documentLocation.access_hash;
|
||||||
}
|
}
|
||||||
|
totalBytesCount = documentLocation.size;
|
||||||
ext = documentLocation.file_name;
|
ext = documentLocation.file_name;
|
||||||
int idx = -1;
|
int idx = -1;
|
||||||
if (ext == null || (idx = ext.lastIndexOf(".")) == -1) {
|
if (ext == null || (idx = ext.lastIndexOf(".")) == -1) {
|
||||||
@ -255,62 +144,41 @@ public class FileLoadOperation {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public FileLoadOperation(String url) {
|
|
||||||
httpUrl = url;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void start() {
|
public void start() {
|
||||||
if (state != 0) {
|
if (state != stateIdle) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
state = 1;
|
state = stateDownloading;
|
||||||
if (location == null && httpUrl == null) {
|
if (location == null) {
|
||||||
Utilities.stageQueue.postRunnable(new Runnable() {
|
Utilities.stageQueue.postRunnable(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
delegate.didFailedLoadingFile(FileLoadOperation.this);
|
delegate.didFailedLoadingFile(FileLoadOperation.this, false);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
boolean ignoreCache = false;
|
|
||||||
boolean onlyCache = false;
|
|
||||||
boolean isLocalFile = false;
|
|
||||||
Long mediaId = null;
|
Long mediaId = null;
|
||||||
String fileNameFinal = null;
|
String fileNameFinal = null;
|
||||||
String fileNameTemp = null;
|
String fileNameTemp = null;
|
||||||
String fileNameIv = null;
|
String fileNameIv = null;
|
||||||
if (httpUrl != null) {
|
if (location.volume_id != 0 && location.local_id != 0) {
|
||||||
if (!httpUrl.startsWith("http")) {
|
|
||||||
if (httpUrl.startsWith("thumb://")) {
|
|
||||||
int idx = httpUrl.indexOf(":", 8);
|
|
||||||
if (idx >= 0) {
|
|
||||||
String media = httpUrl.substring(8, idx);
|
|
||||||
mediaId = Long.parseLong(media);
|
|
||||||
fileNameFinal = httpUrl.substring(idx + 1);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
fileNameFinal = httpUrl;
|
|
||||||
}
|
|
||||||
onlyCache = true;
|
|
||||||
isLocalFile = true;
|
|
||||||
} else {
|
|
||||||
fileNameFinal = Utilities.MD5(httpUrl);
|
|
||||||
fileNameTemp = fileNameFinal + "_temp.jpg";
|
|
||||||
fileNameFinal += ".jpg";
|
|
||||||
}
|
|
||||||
} else if (location.volume_id != 0 && location.local_id != 0) {
|
|
||||||
fileNameTemp = location.volume_id + "_" + location.local_id + "_temp.jpg";
|
fileNameTemp = location.volume_id + "_" + location.local_id + "_temp.jpg";
|
||||||
fileNameFinal = location.volume_id + "_" + location.local_id + ".jpg";
|
fileNameFinal = location.volume_id + "_" + location.local_id + ".jpg";
|
||||||
if (key != null) {
|
if (key != null) {
|
||||||
fileNameIv = location.volume_id + "_" + location.local_id + ".iv";
|
fileNameIv = location.volume_id + "_" + location.local_id + ".iv";
|
||||||
}
|
}
|
||||||
if (datacenter_id == Integer.MIN_VALUE || location.volume_id == Integer.MIN_VALUE) {
|
if (datacenter_id == Integer.MIN_VALUE || location.volume_id == Integer.MIN_VALUE) {
|
||||||
onlyCache = true;
|
cleanup();
|
||||||
|
Utilities.stageQueue.postRunnable(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
delegate.didFailedLoadingFile(FileLoadOperation.this, false);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
ignoreCache = true;
|
|
||||||
needBitmapCreate = false;
|
|
||||||
fileNameTemp = datacenter_id + "_" + location.id + "_temp" + ext;
|
fileNameTemp = datacenter_id + "_" + location.id + "_temp" + ext;
|
||||||
fileNameFinal = datacenter_id + "_" + location.id + ext;
|
fileNameFinal = datacenter_id + "_" + location.id + ext;
|
||||||
if (key != null) {
|
if (key != null) {
|
||||||
@ -318,146 +186,21 @@ public class FileLoadOperation {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
boolean exist;
|
cacheFileFinal = new File(FileLoader.getInstance().getCacheDir(), fileNameFinal);
|
||||||
if (isLocalFile) {
|
boolean exist = cacheFileFinal.exists();
|
||||||
cacheFileFinal = new File(fileNameFinal);
|
if (exist && totalBytesCount != 0 && totalBytesCount != cacheFileFinal.length()) {
|
||||||
} else {
|
exist = false;
|
||||||
cacheFileFinal = new File(AndroidUtilities.getCacheDir(), fileNameFinal);
|
|
||||||
}
|
|
||||||
final boolean dontDelete = isLocalFile;
|
|
||||||
final Long mediaIdFinal = mediaId;
|
|
||||||
if ((exist = cacheFileFinal.exists()) && !ignoreCache) {
|
|
||||||
FileLoader.cacheOutQueue.postRunnable(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
try {
|
|
||||||
int delay = 20;
|
|
||||||
if (FileLoader.getInstance().runtimeHack != null) {
|
|
||||||
delay = 60;
|
|
||||||
}
|
|
||||||
if (mediaIdFinal != null) {
|
|
||||||
delay = 0;
|
|
||||||
}
|
|
||||||
if (delay != 0 && FileLoader.lastCacheOutTime != 0 && FileLoader.lastCacheOutTime > System.currentTimeMillis() - delay) {
|
|
||||||
Thread.sleep(delay);
|
|
||||||
}
|
|
||||||
FileLoader.lastCacheOutTime = System.currentTimeMillis();
|
|
||||||
if (state != 1) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (needBitmapCreate) {
|
|
||||||
BitmapFactory.Options opts = new BitmapFactory.Options();
|
|
||||||
|
|
||||||
float w_filter = 0;
|
|
||||||
float h_filter = 0;
|
|
||||||
boolean blur = false;
|
|
||||||
if (filter != null) {
|
|
||||||
String args[] = filter.split("_");
|
|
||||||
w_filter = Float.parseFloat(args[0]) * AndroidUtilities.density;
|
|
||||||
h_filter = Float.parseFloat(args[1]) * AndroidUtilities.density;
|
|
||||||
if (args.length > 2) {
|
|
||||||
blur = true;
|
|
||||||
}
|
|
||||||
opts.inJustDecodeBounds = true;
|
|
||||||
|
|
||||||
if (mediaIdFinal != null) {
|
|
||||||
MediaStore.Images.Thumbnails.getThumbnail(ApplicationLoader.applicationContext.getContentResolver(), mediaIdFinal, MediaStore.Images.Thumbnails.MINI_KIND, opts);
|
|
||||||
} else {
|
|
||||||
BitmapFactory.decodeFile(cacheFileFinal.getAbsolutePath(), opts);
|
|
||||||
}
|
|
||||||
|
|
||||||
float photoW = opts.outWidth;
|
|
||||||
float photoH = opts.outHeight;
|
|
||||||
float scaleFactor = Math.max(photoW / w_filter, photoH / h_filter);
|
|
||||||
if (scaleFactor < 1) {
|
|
||||||
scaleFactor = 1;
|
|
||||||
}
|
|
||||||
opts.inJustDecodeBounds = false;
|
|
||||||
opts.inSampleSize = (int)scaleFactor;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (filter == null || blur) {
|
|
||||||
opts.inPreferredConfig = Bitmap.Config.ARGB_8888;
|
|
||||||
} else {
|
|
||||||
opts.inPreferredConfig = Bitmap.Config.RGB_565;
|
|
||||||
}
|
|
||||||
opts.inDither = false;
|
|
||||||
if (mediaIdFinal != null) {
|
|
||||||
image = MediaStore.Images.Thumbnails.getThumbnail(ApplicationLoader.applicationContext.getContentResolver(), mediaIdFinal, MediaStore.Images.Thumbnails.MINI_KIND, null);
|
|
||||||
}
|
|
||||||
if (image == null) {
|
|
||||||
FileInputStream is = new FileInputStream(cacheFileFinal);
|
|
||||||
image = BitmapFactory.decodeStream(is, null, opts);
|
|
||||||
is.close();
|
|
||||||
}
|
|
||||||
if (image == null) {
|
|
||||||
if (!dontDelete && (cacheFileFinal.length() == 0 || filter == null)) {
|
|
||||||
cacheFileFinal.delete();
|
cacheFileFinal.delete();
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
if (filter != null) {
|
if (!cacheFileFinal.exists()) {
|
||||||
float bitmapW = image.getWidth();
|
cacheFileTemp = new File(FileLoader.getInstance().getCacheDir(), fileNameTemp);
|
||||||
float bitmapH = image.getHeight();
|
|
||||||
if (bitmapW != w_filter && bitmapW > w_filter) {
|
|
||||||
float scaleFactor = bitmapW / w_filter;
|
|
||||||
Bitmap scaledBitmap = Bitmap.createScaledBitmap(image, (int)w_filter, (int)(bitmapH / scaleFactor), true);
|
|
||||||
if (image != scaledBitmap) {
|
|
||||||
image.recycle();
|
|
||||||
image = scaledBitmap;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (image != null && blur && bitmapH < 100 && bitmapW < 100) {
|
|
||||||
Utilities.blurBitmap(image, (int)bitmapW, (int)bitmapH, image.getRowBytes());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (FileLoader.getInstance().runtimeHack != null) {
|
|
||||||
FileLoader.getInstance().runtimeHack.trackFree(image.getRowBytes() * image.getHeight());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Utilities.stageQueue.postRunnable(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
if (image == null) {
|
|
||||||
delegate.didFailedLoadingFile(FileLoadOperation.this);
|
|
||||||
} else {
|
|
||||||
delegate.didFinishLoadingFile(FileLoadOperation.this);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} catch (Exception e) {
|
|
||||||
if (!dontDelete && cacheFileFinal.length() == 0) {
|
|
||||||
cacheFileFinal.delete();
|
|
||||||
}
|
|
||||||
Utilities.stageQueue.postRunnable(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
delegate.didFailedLoadingFile(FileLoadOperation.this);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
FileLog.e("tmessages", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
if (onlyCache) {
|
|
||||||
cleanup();
|
|
||||||
Utilities.stageQueue.postRunnable(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
delegate.didFailedLoadingFile(FileLoadOperation.this);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
cacheFileTemp = new File(AndroidUtilities.getCacheDir(), fileNameTemp);
|
|
||||||
if (cacheFileTemp.exists()) {
|
if (cacheFileTemp.exists()) {
|
||||||
downloadedBytes = (int)cacheFileTemp.length();
|
downloadedBytes = (int)cacheFileTemp.length();
|
||||||
nextDownloadOffset = downloadedBytes = downloadedBytes / 1024 * 1024;
|
nextDownloadOffset = downloadedBytes = downloadedBytes / 1024 * 1024;
|
||||||
}
|
}
|
||||||
if (fileNameIv != null) {
|
if (fileNameIv != null) {
|
||||||
cacheIvTemp = new File(AndroidUtilities.getCacheDir(), fileNameIv);
|
cacheIvTemp = new File(FileLoader.getInstance().getCacheDir(), fileNameIv);
|
||||||
try {
|
try {
|
||||||
fiv = new RandomAccessFile(cacheIvTemp, "rws");
|
fiv = new RandomAccessFile(cacheIvTemp, "rws");
|
||||||
long len = cacheIvTemp.length();
|
long len = cacheIvTemp.length();
|
||||||
@ -471,9 +214,6 @@ public class FileLoadOperation {
|
|||||||
downloadedBytes = 0;
|
downloadedBytes = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (exist) {
|
|
||||||
cacheFileFinal.delete();
|
|
||||||
}
|
|
||||||
try {
|
try {
|
||||||
fileOutputStream = new RandomAccessFile(cacheFileTemp, "rws");
|
fileOutputStream = new RandomAccessFile(cacheFileTemp, "rws");
|
||||||
if (downloadedBytes != 0) {
|
if (downloadedBytes != 0) {
|
||||||
@ -487,14 +227,11 @@ public class FileLoadOperation {
|
|||||||
Utilities.stageQueue.postRunnable(new Runnable() {
|
Utilities.stageQueue.postRunnable(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
delegate.didFailedLoadingFile(FileLoadOperation.this);
|
delegate.didFailedLoadingFile(FileLoadOperation.this, false);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (httpUrl != null) {
|
|
||||||
startDownloadHTTPRequest();
|
|
||||||
} else {
|
|
||||||
Utilities.stageQueue.postRunnable(new Runnable() {
|
Utilities.stageQueue.postRunnable(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
@ -502,13 +239,18 @@ public class FileLoadOperation {
|
|||||||
try {
|
try {
|
||||||
onFinishLoadingFile();
|
onFinishLoadingFile();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
delegate.didFailedLoadingFile(FileLoadOperation.this);
|
delegate.didFailedLoadingFile(FileLoadOperation.this, false);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
startDownloadRequest();
|
startDownloadRequest();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
} else {
|
||||||
|
try {
|
||||||
|
onFinishLoadingFile();
|
||||||
|
} catch (Exception e) {
|
||||||
|
delegate.didFailedLoadingFile(FileLoadOperation.this, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -517,29 +259,22 @@ public class FileLoadOperation {
|
|||||||
Utilities.stageQueue.postRunnable(new Runnable() {
|
Utilities.stageQueue.postRunnable(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
if (state != 1) {
|
if (state == stateFinished || state == stateFailed) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
state = 2;
|
state = stateFailed;
|
||||||
cleanup();
|
cleanup();
|
||||||
if (httpUrl == null) {
|
|
||||||
for (RequestInfo requestInfo : requestInfos) {
|
for (RequestInfo requestInfo : requestInfos) {
|
||||||
if (requestInfo.requestToken != 0) {
|
if (requestInfo.requestToken != 0) {
|
||||||
ConnectionsManager.getInstance().cancelRpc(requestInfo.requestToken, true, true);
|
ConnectionsManager.getInstance().cancelRpc(requestInfo.requestToken, true, true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
delegate.didFailedLoadingFile(FileLoadOperation.this, true);
|
||||||
delegate.didFailedLoadingFile(FileLoadOperation.this);
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private void cleanup() {
|
private void cleanup() {
|
||||||
if (httpUrl != null) {
|
|
||||||
if (httpTask != null) {
|
|
||||||
httpTask.cancel(true);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
try {
|
try {
|
||||||
if (fileOutputStream != null) {
|
if (fileOutputStream != null) {
|
||||||
fileOutputStream.close();
|
fileOutputStream.close();
|
||||||
@ -565,120 +300,20 @@ public class FileLoadOperation {
|
|||||||
}
|
}
|
||||||
delayedRequestInfos.clear();
|
delayedRequestInfos.clear();
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
private void onFinishLoadingFile() throws Exception {
|
private void onFinishLoadingFile() throws Exception {
|
||||||
if (state != 1) {
|
if (state != stateDownloading) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
state = 3;
|
state = stateFinished;
|
||||||
cleanup();
|
cleanup();
|
||||||
if (cacheIvTemp != null) {
|
if (cacheIvTemp != null) {
|
||||||
cacheIvTemp.delete();
|
cacheIvTemp.delete();
|
||||||
}
|
}
|
||||||
final boolean renamed = cacheFileTemp.renameTo(cacheFileFinal);
|
if (cacheFileTemp != null) {
|
||||||
if (needBitmapCreate) {
|
cacheFileTemp.renameTo(cacheFileFinal);
|
||||||
FileLoader.cacheOutQueue.postRunnable(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
int delay = 20;
|
|
||||||
if (FileLoader.getInstance().runtimeHack != null) {
|
|
||||||
delay = 60;
|
|
||||||
}
|
|
||||||
if (FileLoader.lastCacheOutTime != 0 && FileLoader.lastCacheOutTime > System.currentTimeMillis() - delay) {
|
|
||||||
try {
|
|
||||||
Thread.sleep(delay);
|
|
||||||
} catch (Exception e) {
|
|
||||||
FileLog.e("tmessages", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
BitmapFactory.Options opts = new BitmapFactory.Options();
|
|
||||||
|
|
||||||
float w_filter = 0;
|
|
||||||
float h_filter;
|
|
||||||
boolean blur = false;
|
|
||||||
if (filter != null) {
|
|
||||||
String args[] = filter.split("_");
|
|
||||||
w_filter = Float.parseFloat(args[0]) * AndroidUtilities.density;
|
|
||||||
h_filter = Float.parseFloat(args[1]) * AndroidUtilities.density;
|
|
||||||
if (args.length > 2) {
|
|
||||||
blur = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
opts.inJustDecodeBounds = true;
|
|
||||||
BitmapFactory.decodeFile(cacheFileFinal.getAbsolutePath(), opts);
|
|
||||||
float photoW = opts.outWidth;
|
|
||||||
float photoH = opts.outHeight;
|
|
||||||
float scaleFactor = Math.max(photoW / w_filter, photoH / h_filter);
|
|
||||||
if (scaleFactor < 1) {
|
|
||||||
scaleFactor = 1;
|
|
||||||
}
|
|
||||||
opts.inJustDecodeBounds = false;
|
|
||||||
opts.inSampleSize = (int) scaleFactor;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (filter == null || blur) {
|
|
||||||
opts.inPreferredConfig = Bitmap.Config.ARGB_8888;
|
|
||||||
} else {
|
|
||||||
opts.inPreferredConfig = Bitmap.Config.RGB_565;
|
|
||||||
}
|
|
||||||
|
|
||||||
opts.inDither = false;
|
|
||||||
try {
|
|
||||||
if (renamed) {
|
|
||||||
image = BitmapFactory.decodeStream(new FileInputStream(cacheFileFinal), null, opts);
|
|
||||||
} else {
|
|
||||||
try {
|
|
||||||
image = BitmapFactory.decodeStream(new FileInputStream(cacheFileTemp), null, opts);
|
|
||||||
} catch (Exception e) {
|
|
||||||
FileLog.e("tmessages", e);
|
|
||||||
image = BitmapFactory.decodeStream(new FileInputStream(cacheFileFinal), null, opts);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (filter != null && image != null) {
|
|
||||||
float bitmapW = image.getWidth();
|
|
||||||
float bitmapH = image.getHeight();
|
|
||||||
if (bitmapW != w_filter && bitmapW > w_filter) {
|
|
||||||
float scaleFactor = bitmapW / w_filter;
|
|
||||||
Bitmap scaledBitmap = Bitmap.createScaledBitmap(image, (int) w_filter, (int) (bitmapH / scaleFactor), true);
|
|
||||||
if (image != scaledBitmap) {
|
|
||||||
image.recycle();
|
|
||||||
image = scaledBitmap;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (image != null && blur && bitmapH < 100 && bitmapW < 100) {
|
|
||||||
Utilities.blurBitmap(image, (int)bitmapW, (int)bitmapH, image.getRowBytes());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (image != null && FileLoader.getInstance().runtimeHack != null) {
|
|
||||||
FileLoader.getInstance().runtimeHack.trackFree(image.getRowBytes() * image.getHeight());
|
|
||||||
}
|
|
||||||
if (image != null) {
|
|
||||||
delegate.didFinishLoadingFile(FileLoadOperation.this);
|
|
||||||
} else {
|
|
||||||
delegate.didFailedLoadingFile(FileLoadOperation.this);
|
|
||||||
}
|
|
||||||
} catch (Exception e) {
|
|
||||||
FileLog.e("tmessages", e);
|
|
||||||
delegate.didFailedLoadingFile(FileLoadOperation.this);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
delegate.didFinishLoadingFile(FileLoadOperation.this);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void startDownloadHTTPRequest() {
|
|
||||||
if (state != 1) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
httpTask = new DownloadImageTask();
|
|
||||||
if (android.os.Build.VERSION.SDK_INT >= 11) {
|
|
||||||
httpTask.executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR, null, null, null);
|
|
||||||
} else {
|
|
||||||
httpTask.execute(null, null, null);
|
|
||||||
}
|
}
|
||||||
|
delegate.didFinishLoadingFile(FileLoadOperation.this, cacheFileFinal, cacheFileTemp);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void processRequestResult(RequestInfo requestInfo, TLRPC.TL_error error) {
|
private void processRequestResult(RequestInfo requestInfo, TLRPC.TL_error error) {
|
||||||
@ -686,7 +321,7 @@ public class FileLoadOperation {
|
|||||||
if (error == null) {
|
if (error == null) {
|
||||||
try {
|
try {
|
||||||
if (downloadedBytes != requestInfo.offset) {
|
if (downloadedBytes != requestInfo.offset) {
|
||||||
if (state == 1) {
|
if (state == stateDownloading) {
|
||||||
delayedRequestInfos.add(requestInfo);
|
delayedRequestInfos.add(requestInfo);
|
||||||
requestInfo.response.disableFree = true;
|
requestInfo.response.disableFree = true;
|
||||||
}
|
}
|
||||||
@ -709,7 +344,7 @@ public class FileLoadOperation {
|
|||||||
fiv.write(iv);
|
fiv.write(iv);
|
||||||
}
|
}
|
||||||
downloadedBytes += requestInfo.response.bytes.limit();
|
downloadedBytes += requestInfo.response.bytes.limit();
|
||||||
if (totalBytesCount > 0 && state == 1) {
|
if (totalBytesCount > 0 && state == stateDownloading) {
|
||||||
delegate.didChangedLoadProgress(FileLoadOperation.this, Math.min(1.0f, (float)downloadedBytes / (float)totalBytesCount));
|
delegate.didChangedLoadProgress(FileLoadOperation.this, Math.min(1.0f, (float)downloadedBytes / (float)totalBytesCount));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -732,7 +367,7 @@ public class FileLoadOperation {
|
|||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
cleanup();
|
cleanup();
|
||||||
delegate.didFailedLoadingFile(FileLoadOperation.this);
|
delegate.didFailedLoadingFile(FileLoadOperation.this, false);
|
||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -748,7 +383,7 @@ public class FileLoadOperation {
|
|||||||
}
|
}
|
||||||
if (val == null) {
|
if (val == null) {
|
||||||
cleanup();
|
cleanup();
|
||||||
delegate.didFailedLoadingFile(FileLoadOperation.this);
|
delegate.didFailedLoadingFile(FileLoadOperation.this, false);
|
||||||
} else {
|
} else {
|
||||||
datacenter_id = val;
|
datacenter_id = val;
|
||||||
nextDownloadOffset = 0;
|
nextDownloadOffset = 0;
|
||||||
@ -761,24 +396,24 @@ public class FileLoadOperation {
|
|||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
cleanup();
|
cleanup();
|
||||||
delegate.didFailedLoadingFile(FileLoadOperation.this);
|
delegate.didFailedLoadingFile(FileLoadOperation.this, false);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
cleanup();
|
cleanup();
|
||||||
delegate.didFailedLoadingFile(FileLoadOperation.this);
|
delegate.didFailedLoadingFile(FileLoadOperation.this, false);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (location != null) {
|
if (location != null) {
|
||||||
FileLog.e("tmessages", "" + location + " id = " + location.id + " access_hash = " + location.access_hash + " volume_id = " + location.local_id + " secret = " + location.secret);
|
FileLog.e("tmessages", "" + location + " id = " + location.id + " access_hash = " + location.access_hash + " volume_id = " + location.local_id + " secret = " + location.secret);
|
||||||
}
|
}
|
||||||
cleanup();
|
cleanup();
|
||||||
delegate.didFailedLoadingFile(FileLoadOperation.this);
|
delegate.didFailedLoadingFile(FileLoadOperation.this, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void startDownloadRequest() {
|
private void startDownloadRequest() {
|
||||||
if (state != 1 || totalBytesCount > 0 && nextDownloadOffset >= totalBytesCount || requestInfos.size() + delayedRequestInfos.size() >= maxDownloadRequests) {
|
if (state != stateDownloading || totalBytesCount > 0 && nextDownloadOffset >= totalBytesCount || requestInfos.size() + delayedRequestInfos.size() >= maxDownloadRequests) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
int count = 1;
|
int count = 1;
|
||||||
@ -809,4 +444,8 @@ public class FileLoadOperation {
|
|||||||
}, null, true, RPCRequest.RPCRequestClassDownloadMedia, datacenter_id, isLast);
|
}, null, true, RPCRequest.RPCRequestClassDownloadMedia, datacenter_id, isLast);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setDelegate(FileLoadOperationDelegate delegate) {
|
||||||
|
this.delegate = delegate;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -420,6 +420,7 @@ public class TLClassStore {
|
|||||||
classStore.put(TLRPC.TL_notifyChats.constructor, TLRPC.TL_notifyChats.class);
|
classStore.put(TLRPC.TL_notifyChats.constructor, TLRPC.TL_notifyChats.class);
|
||||||
classStore.put(TLRPC.TL_notifyUsers.constructor, TLRPC.TL_notifyUsers.class);
|
classStore.put(TLRPC.TL_notifyUsers.constructor, TLRPC.TL_notifyUsers.class);
|
||||||
classStore.put(TLRPC.TL_notifyPeer.constructor, TLRPC.TL_notifyPeer.class);
|
classStore.put(TLRPC.TL_notifyPeer.constructor, TLRPC.TL_notifyPeer.class);
|
||||||
|
classStore.put(TLRPC.TL_photos_deletePhotos.constructor, TLRPC.TL_photos_deletePhotos.class);
|
||||||
|
|
||||||
classStore.put(TLRPC.TL_msg_container.constructor, TLRPC.TL_msg_container.class);
|
classStore.put(TLRPC.TL_msg_container.constructor, TLRPC.TL_msg_container.class);
|
||||||
classStore.put(TLRPC.TL_fileEncryptedLocation.constructor, TLRPC.TL_fileEncryptedLocation.class);
|
classStore.put(TLRPC.TL_fileEncryptedLocation.constructor, TLRPC.TL_fileEncryptedLocation.class);
|
||||||
|
@ -1988,17 +1988,6 @@ public class TLRPC {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class User extends TLObject {
|
|
||||||
public int id;
|
|
||||||
public String first_name;
|
|
||||||
public String last_name;
|
|
||||||
public long access_hash;
|
|
||||||
public String phone;
|
|
||||||
public UserProfilePhoto photo;
|
|
||||||
public UserStatus status;
|
|
||||||
public boolean inactive;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class TL_userContact extends User {
|
public static class TL_userContact extends User {
|
||||||
public static int constructor = 0xf2fb8319;
|
public static int constructor = 0xf2fb8319;
|
||||||
|
|
||||||
@ -7443,6 +7432,32 @@ public class TLRPC {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static class TL_photos_deletePhotos extends TLObject {
|
||||||
|
public static int constructor = 0x87cf7f2f;
|
||||||
|
|
||||||
|
public ArrayList<InputPhoto> id = new ArrayList<InputPhoto>();
|
||||||
|
|
||||||
|
public Class responseClass () {
|
||||||
|
return Vector.class;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void parseVector(Vector vector, AbsSerializedData data) {
|
||||||
|
int size = data.readInt32();
|
||||||
|
for (int a = 0; a < size; a++) {
|
||||||
|
vector.objects.add(data.readInt64());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void serializeToStream(AbsSerializedData stream) {
|
||||||
|
stream.writeInt32(constructor);
|
||||||
|
stream.writeInt32(0x1cb5c415);
|
||||||
|
stream.writeInt32(id.size());
|
||||||
|
for (InputPhoto inputPhoto : id) {
|
||||||
|
inputPhoto.serializeToStream(stream);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static class TL_photos_uploadProfilePhoto extends TLObject {
|
public static class TL_photos_uploadProfilePhoto extends TLObject {
|
||||||
public static int constructor = 0xd50f9c88;
|
public static int constructor = 0xd50f9c88;
|
||||||
|
|
||||||
@ -8697,6 +8712,17 @@ public class TLRPC {
|
|||||||
public ArrayList<Object> objects = new ArrayList<Object>();
|
public ArrayList<Object> objects = new ArrayList<Object>();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static class User extends TLObject {
|
||||||
|
public int id;
|
||||||
|
public String first_name;
|
||||||
|
public String last_name;
|
||||||
|
public long access_hash;
|
||||||
|
public String phone;
|
||||||
|
public UserProfilePhoto photo;
|
||||||
|
public UserStatus status;
|
||||||
|
public boolean inactive;
|
||||||
|
}
|
||||||
|
|
||||||
public static class TL_userEmpty extends User {
|
public static class TL_userEmpty extends User {
|
||||||
public static int constructor = 0x200250ba;
|
public static int constructor = 0x200250ba;
|
||||||
|
|
||||||
@ -8860,6 +8886,7 @@ public class TLRPC {
|
|||||||
public int last_message_date;
|
public int last_message_date;
|
||||||
public long id;
|
public long id;
|
||||||
public int last_read;
|
public int last_read;
|
||||||
|
public int flags;
|
||||||
|
|
||||||
public void readParams(AbsSerializedData stream) {
|
public void readParams(AbsSerializedData stream) {
|
||||||
peer = (Peer)TLClassStore.Instance().TLdeserialize(stream, stream.readInt32());
|
peer = (Peer)TLClassStore.Instance().TLdeserialize(stream, stream.readInt32());
|
||||||
|
@ -27,6 +27,7 @@ public class UserConfig {
|
|||||||
public static int lastBroadcastId = -1;
|
public static int lastBroadcastId = -1;
|
||||||
public static String contactsHash = "";
|
public static String contactsHash = "";
|
||||||
public static String importHash = "";
|
public static String importHash = "";
|
||||||
|
public static boolean blockedUsersLoaded = false;
|
||||||
private final static Integer sync = 1;
|
private final static Integer sync = 1;
|
||||||
public static boolean saveIncomingPhotos = false;
|
public static boolean saveIncomingPhotos = false;
|
||||||
public static int contactsVersion = 1;
|
public static int contactsVersion = 1;
|
||||||
@ -59,6 +60,7 @@ public class UserConfig {
|
|||||||
editor.putInt("contactsVersion", contactsVersion);
|
editor.putInt("contactsVersion", contactsVersion);
|
||||||
editor.putInt("lastBroadcastId", lastBroadcastId);
|
editor.putInt("lastBroadcastId", lastBroadcastId);
|
||||||
editor.putBoolean("registeredForInternalPush", registeredForInternalPush);
|
editor.putBoolean("registeredForInternalPush", registeredForInternalPush);
|
||||||
|
editor.putBoolean("blockedUsersLoaded", blockedUsersLoaded);
|
||||||
if (currentUser != null) {
|
if (currentUser != null) {
|
||||||
if (withFile) {
|
if (withFile) {
|
||||||
SerializedData data = new SerializedData();
|
SerializedData data = new SerializedData();
|
||||||
@ -178,6 +180,7 @@ public class UserConfig {
|
|||||||
contactsVersion = preferences.getInt("contactsVersion", 0);
|
contactsVersion = preferences.getInt("contactsVersion", 0);
|
||||||
lastBroadcastId = preferences.getInt("lastBroadcastId", -1);
|
lastBroadcastId = preferences.getInt("lastBroadcastId", -1);
|
||||||
registeredForInternalPush = preferences.getBoolean("registeredForInternalPush", false);
|
registeredForInternalPush = preferences.getBoolean("registeredForInternalPush", false);
|
||||||
|
blockedUsersLoaded = preferences.getBoolean("blockedUsersLoaded", false);
|
||||||
String user = preferences.getString("user", null);
|
String user = preferences.getString("user", null);
|
||||||
if (user != null) {
|
if (user != null) {
|
||||||
byte[] userBytes = Base64.decode(user, Base64.DEFAULT);
|
byte[] userBytes = Base64.decode(user, Base64.DEFAULT);
|
||||||
@ -201,6 +204,7 @@ public class UserConfig {
|
|||||||
contactsVersion = 1;
|
contactsVersion = 1;
|
||||||
lastBroadcastId = -1;
|
lastBroadcastId = -1;
|
||||||
saveIncomingPhotos = false;
|
saveIncomingPhotos = false;
|
||||||
|
blockedUsersLoaded = false;
|
||||||
saveConfig(true);
|
saveConfig(true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -62,7 +62,6 @@ import javax.crypto.Cipher;
|
|||||||
public class Utilities {
|
public class Utilities {
|
||||||
public static Pattern pattern = Pattern.compile("[0-9]+");
|
public static Pattern pattern = Pattern.compile("[0-9]+");
|
||||||
public static SecureRandom random = new SecureRandom();
|
public static SecureRandom random = new SecureRandom();
|
||||||
private final static Integer lock = 1;
|
|
||||||
|
|
||||||
public static ArrayList<String> goodPrimes = new ArrayList<String>();
|
public static ArrayList<String> goodPrimes = new ArrayList<String>();
|
||||||
|
|
||||||
@ -501,12 +500,6 @@ public class Utilities {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void RunOnUIThread(Runnable runnable) {
|
|
||||||
synchronized (lock) {
|
|
||||||
ApplicationLoader.applicationHandler.post(runnable);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static int getColorIndex(int id) {
|
public static int getColorIndex(int id) {
|
||||||
int[] arr;
|
int[] arr;
|
||||||
if (id >= 0) {
|
if (id >= 0) {
|
||||||
@ -759,7 +752,7 @@ public class Utilities {
|
|||||||
String result = firstName;
|
String result = firstName;
|
||||||
if (result == null || result.length() == 0) {
|
if (result == null || result.length() == 0) {
|
||||||
result = lastName;
|
result = lastName;
|
||||||
} else if (result.length() != 0 && lastName.length() != 0) {
|
} else if (result.length() != 0 && lastName != null && lastName.length() != 0) {
|
||||||
result += " " + lastName;
|
result += " " + lastName;
|
||||||
}
|
}
|
||||||
return result.trim();
|
return result.trim();
|
||||||
|
@ -86,7 +86,7 @@ public class ContactsActivityAdapter extends SectionedBaseAdapter {
|
|||||||
if (usersAsSections) {
|
if (usersAsSections) {
|
||||||
if (section < ContactsController.getInstance().sortedUsersSectionsArray.size()) {
|
if (section < ContactsController.getInstance().sortedUsersSectionsArray.size()) {
|
||||||
ArrayList<TLRPC.TL_contact> arr = ContactsController.getInstance().usersSectionsDict.get(ContactsController.getInstance().sortedUsersSectionsArray.get(section));
|
ArrayList<TLRPC.TL_contact> arr = ContactsController.getInstance().usersSectionsDict.get(ContactsController.getInstance().sortedUsersSectionsArray.get(section));
|
||||||
user = MessagesController.getInstance().users.get(arr.get(position).user_id);
|
user = MessagesController.getInstance().getUser(arr.get(position).user_id);
|
||||||
count = arr.size();
|
count = arr.size();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -106,7 +106,7 @@ public class ContactsActivityAdapter extends SectionedBaseAdapter {
|
|||||||
}
|
}
|
||||||
return convertView;
|
return convertView;
|
||||||
}
|
}
|
||||||
user = MessagesController.getInstance().users.get(ContactsController.getInstance().contacts.get(position - 1).user_id);
|
user = MessagesController.getInstance().getUser(ContactsController.getInstance().contacts.get(position - 1).user_id);
|
||||||
count = ContactsController.getInstance().contacts.size();
|
count = ContactsController.getInstance().contacts.size();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -12,6 +12,7 @@ import android.content.Context;
|
|||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
|
|
||||||
|
import org.telegram.android.AndroidUtilities;
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.android.ContactsController;
|
import org.telegram.android.ContactsController;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
@ -67,7 +68,7 @@ public class ContactsActivitySearchAdapter extends BaseFragmentAdapter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void processSearch(final String query) {
|
private void processSearch(final String query) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
final ArrayList<TLRPC.TL_contact> contactsCopy = new ArrayList<TLRPC.TL_contact>();
|
final ArrayList<TLRPC.TL_contact> contactsCopy = new ArrayList<TLRPC.TL_contact>();
|
||||||
@ -85,7 +86,7 @@ public class ContactsActivitySearchAdapter extends BaseFragmentAdapter {
|
|||||||
ArrayList<CharSequence> resultArrayNames = new ArrayList<CharSequence>();
|
ArrayList<CharSequence> resultArrayNames = new ArrayList<CharSequence>();
|
||||||
|
|
||||||
for (TLRPC.TL_contact contact : contactsCopy) {
|
for (TLRPC.TL_contact contact : contactsCopy) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(contact.user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(contact.user_id);
|
||||||
if (user.first_name != null && user.first_name.toLowerCase().startsWith(q) || user.last_name != null && user.last_name.toLowerCase().startsWith(q)) {
|
if (user.first_name != null && user.first_name.toLowerCase().startsWith(q) || user.last_name != null && user.last_name.toLowerCase().startsWith(q)) {
|
||||||
if (user.id == UserConfig.getClientUserId()) {
|
if (user.id == UserConfig.getClientUserId()) {
|
||||||
continue;
|
continue;
|
||||||
@ -103,7 +104,7 @@ public class ContactsActivitySearchAdapter extends BaseFragmentAdapter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void updateSearchResults(final ArrayList<TLRPC.User> users, final ArrayList<CharSequence> names) {
|
private void updateSearchResults(final ArrayList<TLRPC.User> users, final ArrayList<CharSequence> names) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
searchResult = users;
|
searchResult = users;
|
||||||
@ -161,7 +162,7 @@ public class ContactsActivitySearchAdapter extends BaseFragmentAdapter {
|
|||||||
((ChatOrUserCell) view).useSeparator = i != searchResult.size() - 1;
|
((ChatOrUserCell) view).useSeparator = i != searchResult.size() - 1;
|
||||||
|
|
||||||
Object obj = searchResult.get(i);
|
Object obj = searchResult.get(i);
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(((TLRPC.User)obj).id);
|
TLRPC.User user = MessagesController.getInstance().getUser(((TLRPC.User)obj).id);
|
||||||
|
|
||||||
if (user != null) {
|
if (user != null) {
|
||||||
((ChatOrUserCell)view).setData(user, null, null, searchResultNames.get(i), null);
|
((ChatOrUserCell)view).setData(user, null, null, searchResultNames.get(i), null);
|
||||||
|
@ -30,7 +30,9 @@ import com.google.android.gms.gcm.GoogleCloudMessaging;
|
|||||||
|
|
||||||
import org.telegram.android.AndroidUtilities;
|
import org.telegram.android.AndroidUtilities;
|
||||||
import org.telegram.android.ContactsController;
|
import org.telegram.android.ContactsController;
|
||||||
|
import org.telegram.android.MediaController;
|
||||||
import org.telegram.android.NotificationsService;
|
import org.telegram.android.NotificationsService;
|
||||||
|
import org.telegram.android.SendMessagesHelper;
|
||||||
import org.telegram.messenger.BuildVars;
|
import org.telegram.messenger.BuildVars;
|
||||||
import org.telegram.messenger.ConnectionsManager;
|
import org.telegram.messenger.ConnectionsManager;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
@ -92,9 +94,11 @@ public class ApplicationLoader extends Application {
|
|||||||
|
|
||||||
UserConfig.loadConfig();
|
UserConfig.loadConfig();
|
||||||
if (UserConfig.getCurrentUser() != null) {
|
if (UserConfig.getCurrentUser() != null) {
|
||||||
MessagesController.getInstance().users.put(UserConfig.getClientUserId(), UserConfig.getCurrentUser());
|
MessagesController.getInstance().putUser(UserConfig.getCurrentUser(), true);
|
||||||
ConnectionsManager.getInstance().applyCountryPortNumber(UserConfig.getCurrentUser().phone);
|
ConnectionsManager.getInstance().applyCountryPortNumber(UserConfig.getCurrentUser().phone);
|
||||||
ConnectionsManager.getInstance().initPushConnection();
|
ConnectionsManager.getInstance().initPushConnection();
|
||||||
|
MessagesController.getInstance().getBlockedUsers(true);
|
||||||
|
SendMessagesHelper.getInstance().checkUnsentMessages();
|
||||||
}
|
}
|
||||||
|
|
||||||
ApplicationLoader app = (ApplicationLoader)ApplicationLoader.applicationContext;
|
ApplicationLoader app = (ApplicationLoader)ApplicationLoader.applicationContext;
|
||||||
@ -102,6 +106,7 @@ public class ApplicationLoader extends Application {
|
|||||||
FileLog.e("tmessages", "app initied");
|
FileLog.e("tmessages", "app initied");
|
||||||
|
|
||||||
ContactsController.getInstance().checkAppAccount();
|
ContactsController.getInstance().checkAppAccount();
|
||||||
|
MediaController.getInstance();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -263,7 +268,7 @@ public class ApplicationLoader extends Application {
|
|||||||
UserConfig.registeredForPush = !isNew;
|
UserConfig.registeredForPush = !isNew;
|
||||||
UserConfig.saveConfig(false);
|
UserConfig.saveConfig(false);
|
||||||
if (UserConfig.getClientUserId() != 0) {
|
if (UserConfig.getClientUserId() != 0) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
MessagesController.getInstance().registerForPush(regid);
|
MessagesController.getInstance().registerForPush(regid);
|
||||||
|
@ -24,8 +24,8 @@ import org.telegram.messenger.TLRPC;
|
|||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.objects.MessageObject;
|
import org.telegram.android.MessageObject;
|
||||||
import org.telegram.ui.Views.ImageReceiver;
|
import org.telegram.android.ImageReceiver;
|
||||||
import org.telegram.ui.Views.ProgressView;
|
import org.telegram.ui.Views.ProgressView;
|
||||||
import org.telegram.ui.Views.SeekBar;
|
import org.telegram.ui.Views.SeekBar;
|
||||||
|
|
||||||
@ -63,8 +63,7 @@ public class ChatAudioCell extends ChatBaseCell implements SeekBar.SeekBarDelega
|
|||||||
super(context, false);
|
super(context, false);
|
||||||
TAG = MediaController.getInstance().generateObserverTag();
|
TAG = MediaController.getInstance().generateObserverTag();
|
||||||
|
|
||||||
avatarImage = new ImageReceiver();
|
avatarImage = new ImageReceiver(this);
|
||||||
avatarImage.parentView = this;
|
|
||||||
seekBar = new SeekBar(context);
|
seekBar = new SeekBar(context);
|
||||||
seekBar.delegate = this;
|
seekBar.delegate = this;
|
||||||
progressView = new ProgressView();
|
progressView = new ProgressView();
|
||||||
@ -120,7 +119,7 @@ public class ChatAudioCell extends ChatBaseCell implements SeekBar.SeekBarDelega
|
|||||||
buttonPressed = 1;
|
buttonPressed = 1;
|
||||||
invalidate();
|
invalidate();
|
||||||
result = true;
|
result = true;
|
||||||
} else if (x >= avatarImage.imageX && x <= avatarImage.imageX + avatarImage.imageW && y >= avatarImage.imageY && y <= avatarImage.imageY + avatarImage.imageH) {
|
} else if (avatarImage.isInsideImage(x, y)) {
|
||||||
avatarPressed = 1;
|
avatarPressed = 1;
|
||||||
result = true;
|
result = true;
|
||||||
}
|
}
|
||||||
@ -149,7 +148,7 @@ public class ChatAudioCell extends ChatBaseCell implements SeekBar.SeekBarDelega
|
|||||||
} else if (event.getAction() == MotionEvent.ACTION_CANCEL) {
|
} else if (event.getAction() == MotionEvent.ACTION_CANCEL) {
|
||||||
avatarPressed = 0;
|
avatarPressed = 0;
|
||||||
} else if (event.getAction() == MotionEvent.ACTION_MOVE) {
|
} else if (event.getAction() == MotionEvent.ACTION_MOVE) {
|
||||||
if (!(x >= avatarImage.imageX && x <= avatarImage.imageX + avatarImage.imageW && y >= avatarImage.imageY && y <= avatarImage.imageY + avatarImage.imageH)) {
|
if (!avatarImage.isInsideImage(x, y)) {
|
||||||
avatarPressed = 0;
|
avatarPressed = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -176,11 +175,11 @@ public class ChatAudioCell extends ChatBaseCell implements SeekBar.SeekBarDelega
|
|||||||
invalidate();
|
invalidate();
|
||||||
}
|
}
|
||||||
} else if (buttonState == 2) {
|
} else if (buttonState == 2) {
|
||||||
FileLoader.getInstance().loadFile(null, null, null, currentMessageObject.messageOwner.media.audio);
|
FileLoader.getInstance().loadFile(currentMessageObject.messageOwner.media.audio, true);
|
||||||
buttonState = 3;
|
buttonState = 3;
|
||||||
invalidate();
|
invalidate();
|
||||||
} else if (buttonState == 3) {
|
} else if (buttonState == 3) {
|
||||||
FileLoader.getInstance().cancelLoadFile(null, null, null, currentMessageObject.messageOwner.media.audio);
|
FileLoader.getInstance().cancelLoadFile(currentMessageObject.messageOwner.media.audio);
|
||||||
buttonState = 2;
|
buttonState = 2;
|
||||||
invalidate();
|
invalidate();
|
||||||
}
|
}
|
||||||
@ -211,7 +210,7 @@ public class ChatAudioCell extends ChatBaseCell implements SeekBar.SeekBarDelega
|
|||||||
|
|
||||||
public void downloadAudioIfNeed() {
|
public void downloadAudioIfNeed() {
|
||||||
if (buttonState == 2) {
|
if (buttonState == 2) {
|
||||||
FileLoader.getInstance().loadFile(null, null, null, currentMessageObject.messageOwner.media.audio);
|
FileLoader.getInstance().loadFile(currentMessageObject.messageOwner.media.audio, true);
|
||||||
buttonState = 3;
|
buttonState = 3;
|
||||||
invalidate();
|
invalidate();
|
||||||
}
|
}
|
||||||
@ -236,7 +235,7 @@ public class ChatAudioCell extends ChatBaseCell implements SeekBar.SeekBarDelega
|
|||||||
progressView.setProgress(0);
|
progressView.setProgress(0);
|
||||||
} else {
|
} else {
|
||||||
buttonState = 3;
|
buttonState = 3;
|
||||||
Float progress = FileLoader.getInstance().fileProgresses.get(fileName);
|
Float progress = FileLoader.getInstance().getFileProgress(fileName);
|
||||||
if (progress != null) {
|
if (progress != null) {
|
||||||
progressView.setProgress(progress);
|
progressView.setProgress(progress);
|
||||||
} else {
|
} else {
|
||||||
@ -260,6 +259,9 @@ public class ChatAudioCell extends ChatBaseCell implements SeekBar.SeekBarDelega
|
|||||||
@Override
|
@Override
|
||||||
public void onProgressDownload(String fileName, float progress) {
|
public void onProgressDownload(String fileName, float progress) {
|
||||||
progressView.setProgress(progress);
|
progressView.setProgress(progress);
|
||||||
|
if (buttonState != 3) {
|
||||||
|
updateButtonState();
|
||||||
|
}
|
||||||
invalidate();
|
invalidate();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -297,27 +299,27 @@ public class ChatAudioCell extends ChatBaseCell implements SeekBar.SeekBarDelega
|
|||||||
protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
|
protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
|
||||||
super.onLayout(changed, left, top, right, bottom);
|
super.onLayout(changed, left, top, right, bottom);
|
||||||
|
|
||||||
|
int x;
|
||||||
|
|
||||||
if (currentMessageObject.isOut()) {
|
if (currentMessageObject.isOut()) {
|
||||||
avatarImage.imageX = layoutWidth - backgroundWidth + AndroidUtilities.dp(9);
|
x = layoutWidth - backgroundWidth + AndroidUtilities.dp(9);
|
||||||
seekBarX = layoutWidth - backgroundWidth + AndroidUtilities.dp(97);
|
seekBarX = layoutWidth - backgroundWidth + AndroidUtilities.dp(97);
|
||||||
buttonX = layoutWidth - backgroundWidth + AndroidUtilities.dp(67);
|
buttonX = layoutWidth - backgroundWidth + AndroidUtilities.dp(67);
|
||||||
timeX = layoutWidth - backgroundWidth + AndroidUtilities.dp(71);
|
timeX = layoutWidth - backgroundWidth + AndroidUtilities.dp(71);
|
||||||
} else {
|
} else {
|
||||||
if (isChat) {
|
if (isChat) {
|
||||||
avatarImage.imageX = AndroidUtilities.dp(69);
|
x = AndroidUtilities.dp(69);
|
||||||
seekBarX = AndroidUtilities.dp(158);
|
seekBarX = AndroidUtilities.dp(158);
|
||||||
buttonX = AndroidUtilities.dp(128);
|
buttonX = AndroidUtilities.dp(128);
|
||||||
timeX = AndroidUtilities.dp(132);
|
timeX = AndroidUtilities.dp(132);
|
||||||
} else {
|
} else {
|
||||||
avatarImage.imageX = AndroidUtilities.dp(16);
|
x = AndroidUtilities.dp(16);
|
||||||
seekBarX = AndroidUtilities.dp(106);
|
seekBarX = AndroidUtilities.dp(106);
|
||||||
buttonX = AndroidUtilities.dp(76);
|
buttonX = AndroidUtilities.dp(76);
|
||||||
timeX = AndroidUtilities.dp(80);
|
timeX = AndroidUtilities.dp(80);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
avatarImage.imageY = AndroidUtilities.dp(9);
|
avatarImage.setImageCoords(x, AndroidUtilities.dp(9), AndroidUtilities.dp(50), AndroidUtilities.dp(50));
|
||||||
avatarImage.imageW = AndroidUtilities.dp(50);
|
|
||||||
avatarImage.imageH = AndroidUtilities.dp(50);
|
|
||||||
|
|
||||||
seekBar.width = backgroundWidth - AndroidUtilities.dp(112);
|
seekBar.width = backgroundWidth - AndroidUtilities.dp(112);
|
||||||
seekBar.height = AndroidUtilities.dp(30);
|
seekBar.height = AndroidUtilities.dp(30);
|
||||||
@ -331,7 +333,7 @@ public class ChatAudioCell extends ChatBaseCell implements SeekBar.SeekBarDelega
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected boolean isUserDataChanged() {
|
protected boolean isUserDataChanged() {
|
||||||
TLRPC.User newUser = MessagesController.getInstance().users.get(currentMessageObject.messageOwner.media.audio.user_id);
|
TLRPC.User newUser = MessagesController.getInstance().getUser(currentMessageObject.messageOwner.media.audio.user_id);
|
||||||
TLRPC.FileLocation newPhoto = null;
|
TLRPC.FileLocation newPhoto = null;
|
||||||
|
|
||||||
if (avatarImage != null && newUser != null && newUser.photo != null) {
|
if (avatarImage != null && newUser != null && newUser.photo != null) {
|
||||||
@ -348,7 +350,7 @@ public class ChatAudioCell extends ChatBaseCell implements SeekBar.SeekBarDelega
|
|||||||
if (uid == 0) {
|
if (uid == 0) {
|
||||||
uid = messageObject.messageOwner.from_id;
|
uid = messageObject.messageOwner.from_id;
|
||||||
}
|
}
|
||||||
audioUser = MessagesController.getInstance().users.get(uid);
|
audioUser = MessagesController.getInstance().getUser(uid);
|
||||||
if (audioUser != null) {
|
if (audioUser != null) {
|
||||||
if (audioUser.photo != null) {
|
if (audioUser.photo != null) {
|
||||||
currentPhoto = audioUser.photo.photo_small;
|
currentPhoto = audioUser.photo.photo_small;
|
||||||
@ -379,7 +381,7 @@ public class ChatAudioCell extends ChatBaseCell implements SeekBar.SeekBarDelega
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
avatarImage.draw(canvas, avatarImage.imageX, avatarImage.imageY, AndroidUtilities.dp(50), AndroidUtilities.dp(50));
|
avatarImage.draw(canvas, avatarImage.getImageX(), avatarImage.getImageY(), AndroidUtilities.dp(50), AndroidUtilities.dp(50));
|
||||||
|
|
||||||
canvas.save();
|
canvas.save();
|
||||||
if (buttonState == 0 || buttonState == 1) {
|
if (buttonState == 0 || buttonState == 1) {
|
||||||
|
@ -28,8 +28,8 @@ import org.telegram.messenger.TLRPC;
|
|||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.objects.MessageObject;
|
import org.telegram.android.MessageObject;
|
||||||
import org.telegram.ui.Views.ImageReceiver;
|
import org.telegram.android.ImageReceiver;
|
||||||
|
|
||||||
public class ChatBaseCell extends BaseCell {
|
public class ChatBaseCell extends BaseCell {
|
||||||
|
|
||||||
@ -150,8 +150,7 @@ public class ChatBaseCell extends BaseCell {
|
|||||||
super(context);
|
super(context);
|
||||||
init();
|
init();
|
||||||
media = isMedia;
|
media = isMedia;
|
||||||
avatarImage = new ImageReceiver();
|
avatarImage = new ImageReceiver(this);
|
||||||
avatarImage.parentView = this;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -222,7 +221,7 @@ public class ChatBaseCell extends BaseCell {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
TLRPC.User newUser = MessagesController.getInstance().users.get(currentMessageObject.messageOwner.from_id);
|
TLRPC.User newUser = MessagesController.getInstance().getUser(currentMessageObject.messageOwner.from_id);
|
||||||
TLRPC.FileLocation newPhoto = null;
|
TLRPC.FileLocation newPhoto = null;
|
||||||
|
|
||||||
if (isAvatarVisible && newUser != null && newUser.photo != null) {
|
if (isAvatarVisible && newUser != null && newUser.photo != null) {
|
||||||
@ -242,7 +241,7 @@ public class ChatBaseCell extends BaseCell {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
newUser = MessagesController.getInstance().users.get(currentMessageObject.messageOwner.fwd_from_id);
|
newUser = MessagesController.getInstance().getUser(currentMessageObject.messageOwner.fwd_from_id);
|
||||||
newNameString = null;
|
newNameString = null;
|
||||||
if (newUser != null && drawForwardedName && currentMessageObject.messageOwner instanceof TLRPC.TL_messageForwarded) {
|
if (newUser != null && drawForwardedName && currentMessageObject.messageOwner instanceof TLRPC.TL_messageForwarded) {
|
||||||
newNameString = Utilities.formatName(newUser.first_name, newUser.last_name);
|
newNameString = Utilities.formatName(newUser.first_name, newUser.last_name);
|
||||||
@ -258,13 +257,7 @@ public class ChatBaseCell extends BaseCell {
|
|||||||
isAvatarVisible = false;
|
isAvatarVisible = false;
|
||||||
wasLayout = false;
|
wasLayout = false;
|
||||||
|
|
||||||
if (currentMessageObject.messageOwner.id < 0 && currentMessageObject.messageOwner.send_state != MessagesController.MESSAGE_SEND_STATE_SEND_ERROR && currentMessageObject.messageOwner.send_state != MessagesController.MESSAGE_SEND_STATE_SENT) {
|
currentUser = MessagesController.getInstance().getUser(messageObject.messageOwner.from_id);
|
||||||
if (MessagesController.getInstance().sendingMessages.get(currentMessageObject.messageOwner.id) == null) {
|
|
||||||
currentMessageObject.messageOwner.send_state = MessagesController.MESSAGE_SEND_STATE_SEND_ERROR;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
currentUser = MessagesController.getInstance().users.get(messageObject.messageOwner.from_id);
|
|
||||||
if (isChat && !messageObject.isOut()) {
|
if (isChat && !messageObject.isOut()) {
|
||||||
isAvatarVisible = true;
|
isAvatarVisible = true;
|
||||||
if (currentUser != null) {
|
if (currentUser != null) {
|
||||||
@ -314,7 +307,7 @@ public class ChatBaseCell extends BaseCell {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (drawForwardedName && messageObject.messageOwner instanceof TLRPC.TL_messageForwarded) {
|
if (drawForwardedName && messageObject.messageOwner instanceof TLRPC.TL_messageForwarded) {
|
||||||
currentForwardUser = MessagesController.getInstance().users.get(messageObject.messageOwner.fwd_from_id);
|
currentForwardUser = MessagesController.getInstance().getUser(messageObject.messageOwner.fwd_from_id);
|
||||||
if (currentForwardUser != null) {
|
if (currentForwardUser != null) {
|
||||||
currentForwardNameString = Utilities.formatName(currentForwardUser.first_name, currentForwardUser.last_name);
|
currentForwardNameString = Utilities.formatName(currentForwardUser.first_name, currentForwardUser.last_name);
|
||||||
|
|
||||||
@ -380,7 +373,7 @@ public class ChatBaseCell extends BaseCell {
|
|||||||
float y = event.getY();
|
float y = event.getY();
|
||||||
if (event.getAction() == MotionEvent.ACTION_DOWN) {
|
if (event.getAction() == MotionEvent.ACTION_DOWN) {
|
||||||
if (delegate == null || delegate.canPerformActions()) {
|
if (delegate == null || delegate.canPerformActions()) {
|
||||||
if (isAvatarVisible && x >= avatarImage.imageX && x <= avatarImage.imageX + avatarImage.imageW && y >= avatarImage.imageY && y <= avatarImage.imageY + avatarImage.imageH) {
|
if (isAvatarVisible && avatarImage.isInsideImage(x, y)) {
|
||||||
avatarPressed = true;
|
avatarPressed = true;
|
||||||
result = true;
|
result = true;
|
||||||
} else if (drawForwardedName && forwardedNameLayout != null) {
|
} else if (drawForwardedName && forwardedNameLayout != null) {
|
||||||
@ -407,7 +400,7 @@ public class ChatBaseCell extends BaseCell {
|
|||||||
} else if (event.getAction() == MotionEvent.ACTION_CANCEL) {
|
} else if (event.getAction() == MotionEvent.ACTION_CANCEL) {
|
||||||
avatarPressed = false;
|
avatarPressed = false;
|
||||||
} else if (event.getAction() == MotionEvent.ACTION_MOVE) {
|
} else if (event.getAction() == MotionEvent.ACTION_MOVE) {
|
||||||
if (isAvatarVisible && !(x >= avatarImage.imageX && x <= avatarImage.imageX + avatarImage.imageW && y >= avatarImage.imageY && y <= avatarImage.imageY + avatarImage.imageH)) {
|
if (isAvatarVisible && !avatarImage.isInsideImage(x, y)) {
|
||||||
avatarPressed = false;
|
avatarPressed = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -458,10 +451,7 @@ public class ChatBaseCell extends BaseCell {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (isAvatarVisible) {
|
if (isAvatarVisible) {
|
||||||
avatarImage.imageX = AndroidUtilities.dp(6);
|
avatarImage.setImageCoords(AndroidUtilities.dp(6), layoutHeight - AndroidUtilities.dp(45), AndroidUtilities.dp(42), AndroidUtilities.dp(42));
|
||||||
avatarImage.imageY = layoutHeight - AndroidUtilities.dp(45);
|
|
||||||
avatarImage.imageW = AndroidUtilities.dp(42);
|
|
||||||
avatarImage.imageH = AndroidUtilities.dp(42);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
wasLayout = true;
|
wasLayout = true;
|
||||||
@ -575,17 +565,17 @@ public class ChatBaseCell extends BaseCell {
|
|||||||
boolean drawError = false;
|
boolean drawError = false;
|
||||||
boolean isBroadcast = (int)(currentMessageObject.getDialogId() >> 32) == 1;
|
boolean isBroadcast = (int)(currentMessageObject.getDialogId() >> 32) == 1;
|
||||||
|
|
||||||
if (currentMessageObject.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SENDING) {
|
if (currentMessageObject.messageOwner.send_state == MessageObject.MESSAGE_SEND_STATE_SENDING) {
|
||||||
drawCheck1 = false;
|
drawCheck1 = false;
|
||||||
drawCheck2 = false;
|
drawCheck2 = false;
|
||||||
drawClock = true;
|
drawClock = true;
|
||||||
drawError = false;
|
drawError = false;
|
||||||
} else if (currentMessageObject.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SEND_ERROR) {
|
} else if (currentMessageObject.messageOwner.send_state == MessageObject.MESSAGE_SEND_STATE_SEND_ERROR) {
|
||||||
drawCheck1 = false;
|
drawCheck1 = false;
|
||||||
drawCheck2 = false;
|
drawCheck2 = false;
|
||||||
drawClock = false;
|
drawClock = false;
|
||||||
drawError = true;
|
drawError = true;
|
||||||
} else if (currentMessageObject.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SENT) {
|
} else if (currentMessageObject.messageOwner.send_state == MessageObject.MESSAGE_SEND_STATE_SENT) {
|
||||||
if (!currentMessageObject.messageOwner.unread) {
|
if (!currentMessageObject.messageOwner.unread) {
|
||||||
drawCheck1 = true;
|
drawCheck1 = true;
|
||||||
drawCheck2 = true;
|
drawCheck2 = true;
|
||||||
|
@ -20,17 +20,16 @@ import android.view.MotionEvent;
|
|||||||
import android.view.SoundEffectConstants;
|
import android.view.SoundEffectConstants;
|
||||||
|
|
||||||
import org.telegram.android.AndroidUtilities;
|
import org.telegram.android.AndroidUtilities;
|
||||||
import org.telegram.messenger.ConnectionsManager;
|
import org.telegram.android.ImageLoader;
|
||||||
import org.telegram.messenger.FileLoader;
|
import org.telegram.messenger.FileLoader;
|
||||||
import org.telegram.android.MediaController;
|
import org.telegram.android.MediaController;
|
||||||
import org.telegram.android.MessagesController;
|
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.objects.MessageObject;
|
import org.telegram.android.MessageObject;
|
||||||
import org.telegram.objects.PhotoObject;
|
import org.telegram.android.PhotoObject;
|
||||||
import org.telegram.ui.PhotoViewer;
|
import org.telegram.ui.PhotoViewer;
|
||||||
import org.telegram.ui.Views.GifDrawable;
|
import org.telegram.ui.Views.GifDrawable;
|
||||||
import org.telegram.ui.Views.ImageReceiver;
|
import org.telegram.android.ImageReceiver;
|
||||||
import org.telegram.ui.Views.RoundProgressView;
|
import org.telegram.ui.Views.RoundProgressView;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
@ -58,7 +57,6 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
private String currentPhotoFilter;
|
private String currentPhotoFilter;
|
||||||
private ImageReceiver photoImage;
|
private ImageReceiver photoImage;
|
||||||
private RoundProgressView progressView;
|
private RoundProgressView progressView;
|
||||||
public int downloadPhotos = 0;
|
|
||||||
private boolean progressVisible = false;
|
private boolean progressVisible = false;
|
||||||
private boolean photoNotSet = false;
|
private boolean photoNotSet = false;
|
||||||
private boolean cancelLoading = false;
|
private boolean cancelLoading = false;
|
||||||
@ -97,8 +95,7 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
|
|
||||||
TAG = MediaController.getInstance().generateObserverTag();
|
TAG = MediaController.getInstance().generateObserverTag();
|
||||||
|
|
||||||
photoImage = new ImageReceiver();
|
photoImage = new ImageReceiver(this);
|
||||||
photoImage.parentView = this;
|
|
||||||
progressView = new RoundProgressView();
|
progressView = new RoundProgressView();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -138,7 +135,7 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
buttonPressed = 1;
|
buttonPressed = 1;
|
||||||
invalidate();
|
invalidate();
|
||||||
result = true;
|
result = true;
|
||||||
} else if (x >= photoImage.imageX && x <= photoImage.imageX + photoImage.imageW && y >= photoImage.imageY && y <= photoImage.imageY + photoImage.imageH) {
|
} else if (photoImage.isInsideImage(x, y)) {
|
||||||
imagePressed = true;
|
imagePressed = true;
|
||||||
result = true;
|
result = true;
|
||||||
}
|
}
|
||||||
@ -175,7 +172,7 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
imagePressed = false;
|
imagePressed = false;
|
||||||
invalidate();
|
invalidate();
|
||||||
} else if (event.getAction() == MotionEvent.ACTION_MOVE) {
|
} else if (event.getAction() == MotionEvent.ACTION_MOVE) {
|
||||||
if (!(x >= photoImage.imageX && x <= photoImage.imageX + photoImage.imageW && y >= photoImage.imageY && y <= photoImage.imageY + photoImage.imageH)) {
|
if (!photoImage.isInsideImage(x, y)) {
|
||||||
imagePressed = false;
|
imagePressed = false;
|
||||||
invalidate();
|
invalidate();
|
||||||
}
|
}
|
||||||
@ -229,30 +226,30 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
photoImage.setImage(currentPhotoObject.photoOwner.location, currentPhotoFilter, currentMessageObject.isOut() ? placeholderOutDrawable : placeholderInDrawable, currentPhotoObject.photoOwner.size);
|
photoImage.setImage(currentPhotoObject.photoOwner.location, currentPhotoFilter, currentMessageObject.isOut() ? placeholderOutDrawable : placeholderInDrawable, currentPhotoObject.photoOwner.size);
|
||||||
}
|
}
|
||||||
} else if (currentMessageObject.type == 8) {
|
} else if (currentMessageObject.type == 8) {
|
||||||
FileLoader.getInstance().loadFile(null, null, currentMessageObject.messageOwner.media.document, null);
|
FileLoader.getInstance().loadFile(currentMessageObject.messageOwner.media.document);
|
||||||
lastDownloadedGifMessage = currentMessageObject;
|
lastDownloadedGifMessage = currentMessageObject;
|
||||||
} else if (currentMessageObject.type == 3) {
|
} else if (currentMessageObject.type == 3) {
|
||||||
FileLoader.getInstance().loadFile(currentMessageObject.messageOwner.media.video, null, null, null);
|
FileLoader.getInstance().loadFile(currentMessageObject.messageOwner.media.video);
|
||||||
}
|
}
|
||||||
progressVisible = true;
|
progressVisible = true;
|
||||||
buttonState = 1;
|
buttonState = 1;
|
||||||
invalidate();
|
invalidate();
|
||||||
} else if (buttonState == 1) {
|
} else if (buttonState == 1) {
|
||||||
if (currentMessageObject.isOut() && currentMessageObject.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SENDING) {
|
if (currentMessageObject.isOut() && currentMessageObject.messageOwner.send_state == MessageObject.MESSAGE_SEND_STATE_SENDING) {
|
||||||
if (delegate != null) {
|
if (delegate != null) {
|
||||||
delegate.didPressedCancelSendButton(this);
|
delegate.didPressedCancelSendButton(this);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
cancelLoading = true;
|
cancelLoading = true;
|
||||||
if (currentMessageObject.type == 1) {
|
if (currentMessageObject.type == 1) {
|
||||||
FileLoader.getInstance().cancelLoadingForImageView(photoImage);
|
ImageLoader.getInstance().cancelLoadingForImageView(photoImage);
|
||||||
} else if (currentMessageObject.type == 8) {
|
} else if (currentMessageObject.type == 8) {
|
||||||
FileLoader.getInstance().cancelLoadFile(null, null, currentMessageObject.messageOwner.media.document, null);
|
FileLoader.getInstance().cancelLoadFile(currentMessageObject.messageOwner.media.document);
|
||||||
if (lastDownloadedGifMessage != null && lastDownloadedGifMessage.messageOwner.id == currentMessageObject.messageOwner.id) {
|
if (lastDownloadedGifMessage != null && lastDownloadedGifMessage.messageOwner.id == currentMessageObject.messageOwner.id) {
|
||||||
lastDownloadedGifMessage = null;
|
lastDownloadedGifMessage = null;
|
||||||
}
|
}
|
||||||
} else if (currentMessageObject.type == 3) {
|
} else if (currentMessageObject.type == 3) {
|
||||||
FileLoader.getInstance().cancelLoadFile(currentMessageObject.messageOwner.media.video, null, null, null);
|
FileLoader.getInstance().cancelLoadFile(currentMessageObject.messageOwner.media.video);
|
||||||
}
|
}
|
||||||
progressVisible = false;
|
progressVisible = false;
|
||||||
buttonState = 0;
|
buttonState = 0;
|
||||||
@ -289,7 +286,7 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
} else if (currentPhotoObject == null) {
|
} else if (currentPhotoObject == null) {
|
||||||
return true;
|
return true;
|
||||||
} else if (currentPhotoObject != null && photoNotSet) {
|
} else if (currentPhotoObject != null && photoNotSet) {
|
||||||
String fileName = MessageObject.getAttachFileName(currentPhotoObject.photoOwner);
|
String fileName = FileLoader.getAttachFileName(currentPhotoObject.photoOwner);
|
||||||
File cacheFile = new File(AndroidUtilities.getCacheDir(), fileName);
|
File cacheFile = new File(AndroidUtilities.getCacheDir(), fileName);
|
||||||
if (cacheFile.exists()) {
|
if (cacheFile.exists()) {
|
||||||
return true;
|
return true;
|
||||||
@ -402,7 +399,7 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
photoImage.setImageBitmap(currentPhotoObject.image);
|
photoImage.setImageBitmap(currentPhotoObject.image);
|
||||||
} else {
|
} else {
|
||||||
boolean photoExist = true;
|
boolean photoExist = true;
|
||||||
String fileName = MessageObject.getAttachFileName(currentPhotoObject.photoOwner);
|
String fileName = FileLoader.getAttachFileName(currentPhotoObject.photoOwner);
|
||||||
if (messageObject.type == 1) {
|
if (messageObject.type == 1) {
|
||||||
File cacheFile = new File(AndroidUtilities.getCacheDir(), fileName);
|
File cacheFile = new File(AndroidUtilities.getCacheDir(), fileName);
|
||||||
if (!cacheFile.exists()) {
|
if (!cacheFile.exists()) {
|
||||||
@ -411,7 +408,7 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
MediaController.getInstance().removeLoadingFileObserver(this);
|
MediaController.getInstance().removeLoadingFileObserver(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (photoExist || downloadPhotos == 0 || downloadPhotos == 2 && ConnectionsManager.isConnectedToWiFi()) {
|
if (photoExist || MediaController.getInstance().canDownloadMedia(MediaController.AUTODOWNLOAD_MASK_PHOTO)) {
|
||||||
if (messageObject.imagePreview != null) {
|
if (messageObject.imagePreview != null) {
|
||||||
photoImage.setImage(currentPhotoObject.photoOwner.location, currentPhotoFilter, new BitmapDrawable(messageObject.imagePreview), currentPhotoObject.photoOwner.size);
|
photoImage.setImage(currentPhotoObject.photoOwner.location, currentPhotoFilter, new BitmapDrawable(messageObject.imagePreview), currentPhotoObject.photoOwner.size);
|
||||||
} else {
|
} else {
|
||||||
@ -447,7 +444,7 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
if (currentPhotoObject == null) {
|
if (currentPhotoObject == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
fileName = MessageObject.getAttachFileName(currentPhotoObject.photoOwner);
|
fileName = FileLoader.getAttachFileName(currentPhotoObject.photoOwner);
|
||||||
cacheFile = new File(AndroidUtilities.getCacheDir(), fileName);
|
cacheFile = new File(AndroidUtilities.getCacheDir(), fileName);
|
||||||
} else if (currentMessageObject.type == 8 || currentMessageObject.type == 3) {
|
} else if (currentMessageObject.type == 8 || currentMessageObject.type == 3) {
|
||||||
if (currentMessageObject.messageOwner.attachPath != null && currentMessageObject.messageOwner.attachPath.length() != 0) {
|
if (currentMessageObject.messageOwner.attachPath != null && currentMessageObject.messageOwner.attachPath.length() != 0) {
|
||||||
@ -465,20 +462,21 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
if (fileName == null) {
|
if (fileName == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (currentMessageObject.isOut() && currentMessageObject.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SENDING) {
|
if (currentMessageObject.isOut() && currentMessageObject.messageOwner.send_state == MessageObject.MESSAGE_SEND_STATE_SENDING) {
|
||||||
if (currentMessageObject.messageOwner.attachPath != null) {
|
if (currentMessageObject.messageOwner.attachPath != null) {
|
||||||
MediaController.getInstance().addLoadingFileObserver(currentMessageObject.messageOwner.attachPath, this);
|
MediaController.getInstance().addLoadingFileObserver(currentMessageObject.messageOwner.attachPath, this);
|
||||||
progressVisible = true;
|
progressVisible = true;
|
||||||
buttonState = 1;
|
buttonState = 1;
|
||||||
Float progress = FileLoader.getInstance().fileProgresses.get(currentMessageObject.messageOwner.attachPath);
|
Float progress = FileLoader.getInstance().getFileProgress(currentMessageObject.messageOwner.attachPath);
|
||||||
if (progress != null) {
|
if (progress != null) {
|
||||||
progressView.setProgress(progress);
|
progressView.setProgress(progress);
|
||||||
} else {
|
} else {
|
||||||
progressView.setProgress(0);
|
progressView.setProgress(0);
|
||||||
}
|
}
|
||||||
|
invalidate();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (currentMessageObject.messageOwner.attachPath != null) {
|
if (currentMessageObject.messageOwner.attachPath != null && currentMessageObject.messageOwner.attachPath.length() != 0) {
|
||||||
MediaController.getInstance().removeLoadingFileObserver(this);
|
MediaController.getInstance().removeLoadingFileObserver(this);
|
||||||
}
|
}
|
||||||
if (cacheFile.exists() && cacheFile.length() == 0) {
|
if (cacheFile.exists() && cacheFile.length() == 0) {
|
||||||
@ -487,7 +485,7 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
if (!cacheFile.exists()) {
|
if (!cacheFile.exists()) {
|
||||||
MediaController.getInstance().addLoadingFileObserver(fileName, this);
|
MediaController.getInstance().addLoadingFileObserver(fileName, this);
|
||||||
if (!FileLoader.getInstance().isLoadingFile(fileName)) {
|
if (!FileLoader.getInstance().isLoadingFile(fileName)) {
|
||||||
if (cancelLoading || currentMessageObject.type != 1 || downloadPhotos == 1 || downloadPhotos == 2 && !ConnectionsManager.isConnectedToWiFi()) {
|
if (cancelLoading || currentMessageObject.type != 1 || !MediaController.getInstance().canDownloadMedia(MediaController.AUTODOWNLOAD_MASK_PHOTO)) {
|
||||||
buttonState = 0;
|
buttonState = 0;
|
||||||
progressVisible = false;
|
progressVisible = false;
|
||||||
} else {
|
} else {
|
||||||
@ -498,13 +496,14 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
} else {
|
} else {
|
||||||
buttonState = 1;
|
buttonState = 1;
|
||||||
progressVisible = true;
|
progressVisible = true;
|
||||||
Float progress = FileLoader.getInstance().fileProgresses.get(fileName);
|
Float progress = FileLoader.getInstance().getFileProgress(fileName);
|
||||||
if (progress != null) {
|
if (progress != null) {
|
||||||
progressView.setProgress(progress);
|
progressView.setProgress(progress);
|
||||||
} else {
|
} else {
|
||||||
progressView.setProgress(0);
|
progressView.setProgress(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
invalidate();
|
||||||
} else {
|
} else {
|
||||||
MediaController.getInstance().removeLoadingFileObserver(this);
|
MediaController.getInstance().removeLoadingFileObserver(this);
|
||||||
progressVisible = false;
|
progressVisible = false;
|
||||||
@ -529,22 +528,20 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
|
protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
|
||||||
super.onLayout(changed, left, top, right, bottom);
|
super.onLayout(changed, left, top, right, bottom);
|
||||||
|
|
||||||
|
int x;
|
||||||
if (currentMessageObject.isOut()) {
|
if (currentMessageObject.isOut()) {
|
||||||
photoImage.imageX = layoutWidth - backgroundWidth - AndroidUtilities.dp(3);
|
x = layoutWidth - backgroundWidth - AndroidUtilities.dp(3);
|
||||||
} else {
|
} else {
|
||||||
if (isChat) {
|
if (isChat) {
|
||||||
photoImage.imageX = AndroidUtilities.dp(67);
|
x = AndroidUtilities.dp(67);
|
||||||
} else {
|
} else {
|
||||||
photoImage.imageX = AndroidUtilities.dp(15);
|
x = AndroidUtilities.dp(15);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
photoImage.imageY = AndroidUtilities.dp(7);
|
photoImage.setImageCoords(x, AndroidUtilities.dp(7), photoWidth, photoHeight);
|
||||||
photoImage.imageW = photoWidth;
|
|
||||||
photoImage.imageH = photoHeight;
|
|
||||||
|
|
||||||
int size = AndroidUtilities.dp(44);
|
int size = AndroidUtilities.dp(44);
|
||||||
buttonX = (int)(photoImage.imageX + (photoWidth - size) / 2.0f);
|
buttonX = (int)(x + (photoWidth - size) / 2.0f);
|
||||||
buttonY = (int)(photoImage.imageY + (photoHeight - size) / 2.0f);
|
buttonY = (int)(AndroidUtilities.dp(7) + (photoHeight - size) / 2.0f);
|
||||||
progressView.rect.set(buttonX + AndroidUtilities.dp(2), buttonY + AndroidUtilities.dp(2), buttonX + AndroidUtilities.dp(42), buttonY + AndroidUtilities.dp(42));
|
progressView.rect.set(buttonX + AndroidUtilities.dp(2), buttonY + AndroidUtilities.dp(2), buttonX + AndroidUtilities.dp(42), buttonY + AndroidUtilities.dp(42));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -552,12 +549,12 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
protected void onAfterBackgroundDraw(Canvas canvas) {
|
protected void onAfterBackgroundDraw(Canvas canvas) {
|
||||||
if (gifDrawable != null) {
|
if (gifDrawable != null) {
|
||||||
canvas.save();
|
canvas.save();
|
||||||
gifDrawable.setBounds(photoImage.imageX, photoImage.imageY, photoImage.imageX + photoWidth, photoImage.imageY + photoHeight);
|
gifDrawable.setBounds(photoImage.getImageX(), photoImage.getImageY(), photoImage.getImageX() + photoWidth, photoImage.getImageY() + photoHeight);
|
||||||
gifDrawable.draw(canvas);
|
gifDrawable.draw(canvas);
|
||||||
canvas.restore();
|
canvas.restore();
|
||||||
} else {
|
} else {
|
||||||
photoImage.setVisible(!PhotoViewer.getInstance().isShowingImage(currentMessageObject), false);
|
photoImage.setVisible(!PhotoViewer.getInstance().isShowingImage(currentMessageObject), false);
|
||||||
photoImage.draw(canvas, photoImage.imageX, photoImage.imageY, photoWidth, photoHeight);
|
photoImage.draw(canvas, photoImage.getImageX(), photoImage.getImageY(), photoWidth, photoHeight);
|
||||||
drawTime = photoImage.getVisible();
|
drawTime = photoImage.getVisible();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -572,16 +569,16 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (infoLayout != null && (buttonState == 1 || buttonState == 0 || buttonState == 3)) {
|
if (infoLayout != null && (buttonState == 1 || buttonState == 0 || buttonState == 3)) {
|
||||||
setDrawableBounds(mediaBackgroundDrawable, photoImage.imageX + AndroidUtilities.dp(4), photoImage.imageY + AndroidUtilities.dp(4), infoWidth + AndroidUtilities.dp(8) + infoOffset, AndroidUtilities.dpf(16.5f));
|
setDrawableBounds(mediaBackgroundDrawable, photoImage.getImageX() + AndroidUtilities.dp(4), photoImage.getImageY() + AndroidUtilities.dp(4), infoWidth + AndroidUtilities.dp(8) + infoOffset, AndroidUtilities.dpf(16.5f));
|
||||||
mediaBackgroundDrawable.draw(canvas);
|
mediaBackgroundDrawable.draw(canvas);
|
||||||
|
|
||||||
if (currentMessageObject.type == 3) {
|
if (currentMessageObject.type == 3) {
|
||||||
setDrawableBounds(videoIconDrawable, photoImage.imageX + AndroidUtilities.dp(8), photoImage.imageY + AndroidUtilities.dpf(7.5f));
|
setDrawableBounds(videoIconDrawable, photoImage.getImageX() + AndroidUtilities.dp(8), photoImage.getImageY() + AndroidUtilities.dpf(7.5f));
|
||||||
videoIconDrawable.draw(canvas);
|
videoIconDrawable.draw(canvas);
|
||||||
}
|
}
|
||||||
|
|
||||||
canvas.save();
|
canvas.save();
|
||||||
canvas.translate(photoImage.imageX + AndroidUtilities.dp(8) + infoOffset, photoImage.imageY + AndroidUtilities.dpf(5.5f));
|
canvas.translate(photoImage.getImageX() + AndroidUtilities.dp(8) + infoOffset, photoImage.getImageY() + AndroidUtilities.dpf(5.5f));
|
||||||
infoLayout.draw(canvas);
|
infoLayout.draw(canvas);
|
||||||
canvas.restore();
|
canvas.restore();
|
||||||
}
|
}
|
||||||
@ -607,6 +604,9 @@ public class ChatMediaCell extends ChatBaseCell implements MediaController.FileD
|
|||||||
public void onProgressDownload(String fileName, float progress) {
|
public void onProgressDownload(String fileName, float progress) {
|
||||||
progressVisible = true;
|
progressVisible = true;
|
||||||
progressView.setProgress(progress);
|
progressView.setProgress(progress);
|
||||||
|
if (buttonState != 1) {
|
||||||
|
updateButtonState();
|
||||||
|
}
|
||||||
invalidate();
|
invalidate();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -16,7 +16,7 @@ import android.view.MotionEvent;
|
|||||||
|
|
||||||
import org.telegram.android.AndroidUtilities;
|
import org.telegram.android.AndroidUtilities;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.objects.MessageObject;
|
import org.telegram.android.MessageObject;
|
||||||
|
|
||||||
public class ChatMessageCell extends ChatBaseCell {
|
public class ChatMessageCell extends ChatBaseCell {
|
||||||
|
|
||||||
|
@ -26,7 +26,7 @@ import org.telegram.android.MessagesController;
|
|||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.ui.Views.ImageReceiver;
|
import org.telegram.android.ImageReceiver;
|
||||||
|
|
||||||
public class ChatOrUserCell extends BaseCell {
|
public class ChatOrUserCell extends BaseCell {
|
||||||
private static TextPaint namePaint;
|
private static TextPaint namePaint;
|
||||||
@ -104,8 +104,7 @@ public class ChatOrUserCell extends BaseCell {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (avatarImage == null) {
|
if (avatarImage == null) {
|
||||||
avatarImage = new ImageReceiver();
|
avatarImage = new ImageReceiver(this);
|
||||||
avatarImage.parentView = this;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cellLayout == null) {
|
if (cellLayout == null) {
|
||||||
@ -404,10 +403,7 @@ public class ChatOrUserCell extends BaseCell {
|
|||||||
} else {
|
} else {
|
||||||
avatarLeft = width - AndroidUtilities.dp(50 + (usePadding ? 11 : 0));
|
avatarLeft = width - AndroidUtilities.dp(50 + (usePadding ? 11 : 0));
|
||||||
}
|
}
|
||||||
avatarImage.imageX = avatarLeft;
|
avatarImage.setImageCoords(avatarLeft, avatarTop, AndroidUtilities.dp(50), AndroidUtilities.dp(50));
|
||||||
avatarImage.imageY = avatarTop;
|
|
||||||
avatarImage.imageW = AndroidUtilities.dp(50);
|
|
||||||
avatarImage.imageH = AndroidUtilities.dp(50);
|
|
||||||
|
|
||||||
double widthpx = 0;
|
double widthpx = 0;
|
||||||
float left = 0;
|
float left = 0;
|
||||||
|
@ -27,8 +27,8 @@ import org.telegram.android.MessagesController;
|
|||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.objects.MessageObject;
|
import org.telegram.android.MessageObject;
|
||||||
import org.telegram.ui.Views.ImageReceiver;
|
import org.telegram.android.ImageReceiver;
|
||||||
|
|
||||||
public class DialogCell extends BaseCell {
|
public class DialogCell extends BaseCell {
|
||||||
private static TextPaint namePaint;
|
private static TextPaint namePaint;
|
||||||
@ -136,8 +136,7 @@ public class DialogCell extends BaseCell {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (avatarImage == null) {
|
if (avatarImage == null) {
|
||||||
avatarImage = new ImageReceiver();
|
avatarImage = new ImageReceiver(this);
|
||||||
avatarImage.parentView = this;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cellLayout == null) {
|
if (cellLayout == null) {
|
||||||
@ -228,18 +227,18 @@ public class DialogCell extends BaseCell {
|
|||||||
int high_id = (int)(currentDialog.id >> 32);
|
int high_id = (int)(currentDialog.id >> 32);
|
||||||
if (lower_id != 0) {
|
if (lower_id != 0) {
|
||||||
if (high_id == 1) {
|
if (high_id == 1) {
|
||||||
chat = MessagesController.getInstance().chats.get(lower_id);
|
chat = MessagesController.getInstance().getChat(lower_id);
|
||||||
} else {
|
} else {
|
||||||
if (lower_id < 0) {
|
if (lower_id < 0) {
|
||||||
chat = MessagesController.getInstance().chats.get(-lower_id);
|
chat = MessagesController.getInstance().getChat(-lower_id);
|
||||||
} else {
|
} else {
|
||||||
user = MessagesController.getInstance().users.get(lower_id);
|
user = MessagesController.getInstance().getUser(lower_id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
encryptedChat = MessagesController.getInstance().encryptedChats.get(high_id);
|
encryptedChat = MessagesController.getInstance().getEncryptedChat(high_id);
|
||||||
if (encryptedChat != null) {
|
if (encryptedChat != null) {
|
||||||
user = MessagesController.getInstance().users.get(encryptedChat.user_id);
|
user = MessagesController.getInstance().getUser(encryptedChat.user_id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -464,7 +463,7 @@ public class DialogCell extends BaseCell {
|
|||||||
drawCount = false;
|
drawCount = false;
|
||||||
drawError = false;
|
drawError = false;
|
||||||
} else {
|
} else {
|
||||||
TLRPC.User fromUser = MessagesController.getInstance().users.get(message.messageOwner.from_id);
|
TLRPC.User fromUser = MessagesController.getInstance().getUser(message.messageOwner.from_id);
|
||||||
|
|
||||||
if (currentDialog.last_message_date != 0) {
|
if (currentDialog.last_message_date != 0) {
|
||||||
timeString = LocaleController.stringForMessageListDate(currentDialog.last_message_date);
|
timeString = LocaleController.stringForMessageListDate(currentDialog.last_message_date);
|
||||||
@ -518,25 +517,19 @@ public class DialogCell extends BaseCell {
|
|||||||
drawCount = false;
|
drawCount = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (message.messageOwner.id < 0 && message.messageOwner.send_state != MessagesController.MESSAGE_SEND_STATE_SENT) {
|
|
||||||
if (MessagesController.getInstance().sendingMessages.get(message.messageOwner.id) == null) {
|
|
||||||
message.messageOwner.send_state = MessagesController.MESSAGE_SEND_STATE_SEND_ERROR;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (message.isFromMe() && message.isOut()) {
|
if (message.isFromMe() && message.isOut()) {
|
||||||
if (message.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SENDING) {
|
if (message.messageOwner.send_state == MessageObject.MESSAGE_SEND_STATE_SENDING) {
|
||||||
drawCheck1 = false;
|
drawCheck1 = false;
|
||||||
drawCheck2 = false;
|
drawCheck2 = false;
|
||||||
drawClock = true;
|
drawClock = true;
|
||||||
drawError = false;
|
drawError = false;
|
||||||
} else if (message.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SEND_ERROR) {
|
} else if (message.messageOwner.send_state == MessageObject.MESSAGE_SEND_STATE_SEND_ERROR) {
|
||||||
drawCheck1 = false;
|
drawCheck1 = false;
|
||||||
drawCheck2 = false;
|
drawCheck2 = false;
|
||||||
drawClock = false;
|
drawClock = false;
|
||||||
drawError = true;
|
drawError = true;
|
||||||
drawCount = false;
|
drawCount = false;
|
||||||
} else if (message.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SENT) {
|
} else if (message.messageOwner.send_state == MessageObject.MESSAGE_SEND_STATE_SENT) {
|
||||||
if (!message.messageOwner.unread) {
|
if (!message.messageOwner.unread) {
|
||||||
drawCheck1 = true;
|
drawCheck1 = true;
|
||||||
drawCheck2 = true;
|
drawCheck2 = true;
|
||||||
@ -644,10 +637,7 @@ public class DialogCell extends BaseCell {
|
|||||||
messageLeft = AndroidUtilities.dp(11);
|
messageLeft = AndroidUtilities.dp(11);
|
||||||
avatarLeft = width - AndroidUtilities.dp(65);
|
avatarLeft = width - AndroidUtilities.dp(65);
|
||||||
}
|
}
|
||||||
avatarImage.imageX = avatarLeft;
|
avatarImage.setImageCoords(avatarLeft, avatarTop, AndroidUtilities.dp(54), AndroidUtilities.dp(54));
|
||||||
avatarImage.imageY = avatarTop;
|
|
||||||
avatarImage.imageW = AndroidUtilities.dp(54);
|
|
||||||
avatarImage.imageH = AndroidUtilities.dp(54);
|
|
||||||
if (drawError) {
|
if (drawError) {
|
||||||
int w = errorDrawable.getIntrinsicWidth() + AndroidUtilities.dp(8);
|
int w = errorDrawable.getIntrinsicWidth() + AndroidUtilities.dp(8);
|
||||||
messageWidth -= w;
|
messageWidth -= w;
|
||||||
|
@ -50,19 +50,21 @@ import android.widget.Toast;
|
|||||||
|
|
||||||
import org.telegram.android.AndroidUtilities;
|
import org.telegram.android.AndroidUtilities;
|
||||||
import org.telegram.PhoneFormat.PhoneFormat;
|
import org.telegram.PhoneFormat.PhoneFormat;
|
||||||
|
import org.telegram.android.ImageLoader;
|
||||||
import org.telegram.android.LocaleController;
|
import org.telegram.android.LocaleController;
|
||||||
import org.telegram.android.MediaController;
|
import org.telegram.android.MediaController;
|
||||||
import org.telegram.android.MessagesStorage;
|
import org.telegram.android.MessagesStorage;
|
||||||
import org.telegram.android.NotificationsController;
|
import org.telegram.android.NotificationsController;
|
||||||
|
import org.telegram.android.SendMessagesHelper;
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.android.ContactsController;
|
import org.telegram.android.ContactsController;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.objects.MessageObject;
|
import org.telegram.android.MessageObject;
|
||||||
import org.telegram.objects.PhotoObject;
|
import org.telegram.android.PhotoObject;
|
||||||
import org.telegram.messenger.ConnectionsManager;
|
import org.telegram.messenger.ConnectionsManager;
|
||||||
import org.telegram.messenger.FileLoader;
|
import org.telegram.messenger.FileLoader;
|
||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
@ -77,7 +79,7 @@ import org.telegram.ui.Views.ActionBar.ActionBarMenuItem;
|
|||||||
import org.telegram.ui.Views.BackupImageView;
|
import org.telegram.ui.Views.BackupImageView;
|
||||||
import org.telegram.ui.Views.ActionBar.BaseFragment;
|
import org.telegram.ui.Views.ActionBar.BaseFragment;
|
||||||
import org.telegram.ui.Views.ChatActivityEnterView;
|
import org.telegram.ui.Views.ChatActivityEnterView;
|
||||||
import org.telegram.ui.Views.ImageReceiver;
|
import org.telegram.android.ImageReceiver;
|
||||||
import org.telegram.ui.Views.LayoutListView;
|
import org.telegram.ui.Views.LayoutListView;
|
||||||
import org.telegram.ui.Views.MessageActionLayout;
|
import org.telegram.ui.Views.MessageActionLayout;
|
||||||
import org.telegram.ui.Views.SizeNotifierRelativeLayout;
|
import org.telegram.ui.Views.SizeNotifierRelativeLayout;
|
||||||
@ -91,23 +93,26 @@ import java.util.concurrent.Semaphore;
|
|||||||
|
|
||||||
public class ChatActivity extends BaseFragment implements NotificationCenter.NotificationCenterDelegate, MessagesActivity.MessagesActivityDelegate,
|
public class ChatActivity extends BaseFragment implements NotificationCenter.NotificationCenterDelegate, MessagesActivity.MessagesActivityDelegate,
|
||||||
DocumentSelectActivity.DocumentSelectActivityDelegate, PhotoViewer.PhotoViewerProvider, PhotoPickerActivity.PhotoPickerActivityDelegate,
|
DocumentSelectActivity.DocumentSelectActivityDelegate, PhotoViewer.PhotoViewerProvider, PhotoPickerActivity.PhotoPickerActivityDelegate,
|
||||||
VideoEditorActivity.VideoEditorActivityDelegate {
|
VideoEditorActivity.VideoEditorActivityDelegate, LocationActivity.LocationActivityDelegate {
|
||||||
|
|
||||||
private ChatActivityEnterView chatActivityEnterView;
|
|
||||||
private View timeItem;
|
|
||||||
private View menuItem;
|
|
||||||
private LayoutListView chatListView;
|
|
||||||
private BackupImageView avatarImageView;
|
|
||||||
private TLRPC.Chat currentChat;
|
private TLRPC.Chat currentChat;
|
||||||
private TLRPC.User currentUser;
|
private TLRPC.User currentUser;
|
||||||
private TLRPC.EncryptedChat currentEncryptedChat;
|
private TLRPC.EncryptedChat currentEncryptedChat;
|
||||||
private ChatAdapter chatAdapter;
|
private boolean userBlocked = false;
|
||||||
|
|
||||||
private View topPanel;
|
private View topPanel;
|
||||||
private View secretChatPlaceholder;
|
private View secretChatPlaceholder;
|
||||||
private View progressView;
|
private View progressView;
|
||||||
private TextView emptyView;
|
private TextView emptyView;
|
||||||
private View bottomOverlay;
|
private View bottomOverlay;
|
||||||
|
private ChatAdapter chatAdapter;
|
||||||
|
private ChatActivityEnterView chatActivityEnterView;
|
||||||
|
private View timeItem;
|
||||||
|
private View menuItem;
|
||||||
|
private LayoutListView chatListView;
|
||||||
|
private BackupImageView avatarImageView;
|
||||||
|
private TextView bottomOverlayChatText;
|
||||||
|
private View bottomOverlayChat;
|
||||||
|
|
||||||
private TextView bottomOverlayText;
|
private TextView bottomOverlayText;
|
||||||
|
|
||||||
@ -124,8 +129,6 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
private boolean scrollToTopOnResume = false;
|
private boolean scrollToTopOnResume = false;
|
||||||
private boolean scrollToTopUnReadOnResume = false;
|
private boolean scrollToTopUnReadOnResume = false;
|
||||||
private boolean isCustomTheme = false;
|
private boolean isCustomTheme = false;
|
||||||
private int downloadPhotos = 0;
|
|
||||||
private int downloadAudios = 0;
|
|
||||||
private ImageView topPlaneClose;
|
private ImageView topPlaneClose;
|
||||||
private View pagedownButton;
|
private View pagedownButton;
|
||||||
private TextView topPanelText;
|
private TextView topPanelText;
|
||||||
@ -193,7 +196,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
scrollToTopOnResume = arguments.getBoolean("scrollToTopOnResume", false);
|
scrollToTopOnResume = arguments.getBoolean("scrollToTopOnResume", false);
|
||||||
|
|
||||||
if (chatId != 0) {
|
if (chatId != 0) {
|
||||||
currentChat = MessagesController.getInstance().chats.get(chatId);
|
currentChat = MessagesController.getInstance().getChat(chatId);
|
||||||
if (currentChat == null) {
|
if (currentChat == null) {
|
||||||
final Semaphore semaphore = new Semaphore(0);
|
final Semaphore semaphore = new Semaphore(0);
|
||||||
MessagesStorage.getInstance().storageQueue.postRunnable(new Runnable() {
|
MessagesStorage.getInstance().storageQueue.postRunnable(new Runnable() {
|
||||||
@ -209,7 +212,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
if (currentChat != null) {
|
if (currentChat != null) {
|
||||||
MessagesController.getInstance().chats.put(currentChat.id, currentChat);
|
MessagesController.getInstance().putChat(currentChat, true);
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -233,7 +236,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (userId != 0) {
|
} else if (userId != 0) {
|
||||||
currentUser = MessagesController.getInstance().users.get(userId);
|
currentUser = MessagesController.getInstance().getUser(userId);
|
||||||
if (currentUser == null) {
|
if (currentUser == null) {
|
||||||
final Semaphore semaphore = new Semaphore(0);
|
final Semaphore semaphore = new Semaphore(0);
|
||||||
MessagesStorage.getInstance().storageQueue.postRunnable(new Runnable() {
|
MessagesStorage.getInstance().storageQueue.postRunnable(new Runnable() {
|
||||||
@ -249,14 +252,14 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
if (currentUser != null) {
|
if (currentUser != null) {
|
||||||
MessagesController.getInstance().users.putIfAbsent(currentUser.id, currentUser);
|
MessagesController.getInstance().putUser(currentUser, true);
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
dialog_id = userId;
|
dialog_id = userId;
|
||||||
} else if (encId != 0) {
|
} else if (encId != 0) {
|
||||||
currentEncryptedChat = MessagesController.getInstance().encryptedChats.get(encId);
|
currentEncryptedChat = MessagesController.getInstance().getEncryptedChat(encId);
|
||||||
if (currentEncryptedChat == null) {
|
if (currentEncryptedChat == null) {
|
||||||
final Semaphore semaphore = new Semaphore(0);
|
final Semaphore semaphore = new Semaphore(0);
|
||||||
MessagesStorage.getInstance().storageQueue.postRunnable(new Runnable() {
|
MessagesStorage.getInstance().storageQueue.postRunnable(new Runnable() {
|
||||||
@ -272,12 +275,12 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
if (currentEncryptedChat != null) {
|
if (currentEncryptedChat != null) {
|
||||||
MessagesController.getInstance().encryptedChats.putIfAbsent(currentEncryptedChat.id, currentEncryptedChat);
|
MessagesController.getInstance().putEncryptedChat(currentEncryptedChat, true);
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
currentUser = MessagesController.getInstance().users.get(currentEncryptedChat.user_id);
|
currentUser = MessagesController.getInstance().getUser(currentEncryptedChat.user_id);
|
||||||
if (currentUser == null) {
|
if (currentUser == null) {
|
||||||
final Semaphore semaphore = new Semaphore(0);
|
final Semaphore semaphore = new Semaphore(0);
|
||||||
MessagesStorage.getInstance().storageQueue.postRunnable(new Runnable() {
|
MessagesStorage.getInstance().storageQueue.postRunnable(new Runnable() {
|
||||||
@ -293,7 +296,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
if (currentUser != null) {
|
if (currentUser != null) {
|
||||||
MessagesController.getInstance().users.putIfAbsent(currentUser.id, currentUser);
|
MessagesController.getInstance().putUser(currentUser, true);
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -323,29 +326,29 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
MessagesController.getInstance().sendTyping(dialog_id, classGuid);
|
MessagesController.getInstance().sendTyping(dialog_id, classGuid);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.messagesDidLoaded);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.messagesDidLoaded);
|
||||||
NotificationCenter.getInstance().addObserver(this, 999);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.emojiDidLoaded);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.updateInterfaces);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.didReceivedNewMessages);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.didReceivedNewMessages);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.closeChats);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.closeChats);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.messagesReaded);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.messagesReaded);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.messagesDeleted);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.messagesDeleted);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.messageReceivedByServer);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.messageReceivedByServer);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.messageReceivedByAck);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.messageReceivedByAck);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.messageSendError);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.messageSendError);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.chatInfoDidLoaded);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.chatInfoDidLoaded);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.contactsDidLoaded);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.contactsDidLoaded);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.encryptedChatUpdated);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.encryptedChatUpdated);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.messagesReadedEncrypted);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.messagesReadedEncrypted);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.removeAllMessagesFromDialog);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.removeAllMessagesFromDialog);
|
||||||
NotificationCenter.getInstance().addObserver(this, FileLoader.FileUploadProgressChanged);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.FileUploadProgressChanged);
|
||||||
NotificationCenter.getInstance().addObserver(this, FileLoader.FileDidFailedLoad);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.FileDidFailedLoad);
|
||||||
NotificationCenter.getInstance().addObserver(this, FileLoader.FileDidLoaded);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.FileDidLoaded);
|
||||||
NotificationCenter.getInstance().addObserver(this, FileLoader.FileLoadProgressChanged);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.FileLoadProgressChanged);
|
||||||
NotificationCenter.getInstance().addObserver(this, MediaController.audioProgressDidChanged);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.audioProgressDidChanged);
|
||||||
NotificationCenter.getInstance().addObserver(this, MediaController.audioDidReset);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.audioDidReset);
|
||||||
NotificationCenter.getInstance().addObserver(this, MediaController.screenshotTook);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.screenshotTook);
|
||||||
NotificationCenter.getInstance().addObserver(this, 997);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.blockedUsersDidLoaded);
|
||||||
|
|
||||||
super.onFragmentCreate();
|
super.onFragmentCreate();
|
||||||
|
|
||||||
@ -353,12 +356,8 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
MessagesController.getInstance().loadMessages(dialog_id, 30, 0, true, 0, classGuid, true, false);
|
MessagesController.getInstance().loadMessages(dialog_id, 30, 0, true, 0, classGuid, true, false);
|
||||||
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("mainconfig", Activity.MODE_PRIVATE);
|
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("mainconfig", Activity.MODE_PRIVATE);
|
||||||
|
|
||||||
if (currentChat != null) {
|
if (currentUser != null) {
|
||||||
downloadPhotos = preferences.getInt("photo_download_chat2", 0);
|
userBlocked = MessagesController.getInstance().blockedUsers.contains(currentUser.id);
|
||||||
downloadAudios = preferences.getInt("audio_download_chat2", 0);
|
|
||||||
} else {
|
|
||||||
downloadPhotos = preferences.getInt("photo_download_user2", 0);
|
|
||||||
downloadAudios = preferences.getInt("audio_download_user2", 0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
@ -370,29 +369,29 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
if (chatActivityEnterView != null) {
|
if (chatActivityEnterView != null) {
|
||||||
chatActivityEnterView.onDestroy();
|
chatActivityEnterView.onDestroy();
|
||||||
}
|
}
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.messagesDidLoaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.messagesDidLoaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, 999);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.emojiDidLoaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.updateInterfaces);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.didReceivedNewMessages);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.didReceivedNewMessages);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.closeChats);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.closeChats);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.messagesReaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.messagesReaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.messagesDeleted);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.messagesDeleted);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.messageReceivedByServer);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.messageReceivedByServer);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.messageReceivedByAck);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.messageReceivedByAck);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.messageSendError);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.messageSendError);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.chatInfoDidLoaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.chatInfoDidLoaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.encryptedChatUpdated);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.encryptedChatUpdated);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.messagesReadedEncrypted);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.messagesReadedEncrypted);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.removeAllMessagesFromDialog);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.removeAllMessagesFromDialog);
|
||||||
NotificationCenter.getInstance().removeObserver(this, FileLoader.FileUploadProgressChanged);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.FileUploadProgressChanged);
|
||||||
NotificationCenter.getInstance().removeObserver(this, FileLoader.FileDidFailedLoad);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.FileDidFailedLoad);
|
||||||
NotificationCenter.getInstance().removeObserver(this, FileLoader.FileDidLoaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.FileDidLoaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, FileLoader.FileLoadProgressChanged);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.FileLoadProgressChanged);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.contactsDidLoaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.contactsDidLoaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MediaController.audioProgressDidChanged);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.audioProgressDidChanged);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MediaController.audioDidReset);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.audioDidReset);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MediaController.screenshotTook);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.screenshotTook);
|
||||||
NotificationCenter.getInstance().removeObserver(this, 997);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.blockedUsersDidLoaded);
|
||||||
if (currentEncryptedChat != null) {
|
if (currentEncryptedChat != null) {
|
||||||
MediaController.getInstance().stopMediaObserver();
|
MediaController.getInstance().stopMediaObserver();
|
||||||
}
|
}
|
||||||
@ -458,6 +457,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
LocationActivity fragment = new LocationActivity();
|
LocationActivity fragment = new LocationActivity();
|
||||||
|
fragment.setDelegate(ChatActivity.this);
|
||||||
presentFragment(fragment);
|
presentFragment(fragment);
|
||||||
} else if (id == attach_document) {
|
} else if (id == attach_document) {
|
||||||
DocumentSelectActivity fragment = new DocumentSelectActivity();
|
DocumentSelectActivity fragment = new DocumentSelectActivity();
|
||||||
@ -631,7 +631,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
topPanelText = (TextView)fragmentView.findViewById(R.id.top_panel_text);
|
topPanelText = (TextView)fragmentView.findViewById(R.id.top_panel_text);
|
||||||
bottomOverlay = fragmentView.findViewById(R.id.bottom_overlay);
|
bottomOverlay = fragmentView.findViewById(R.id.bottom_overlay);
|
||||||
bottomOverlayText = (TextView)fragmentView.findViewById(R.id.bottom_overlay_text);
|
bottomOverlayText = (TextView)fragmentView.findViewById(R.id.bottom_overlay_text);
|
||||||
View bottomOverlayChat = fragmentView.findViewById(R.id.bottom_overlay_chat);
|
bottomOverlayChat = fragmentView.findViewById(R.id.bottom_overlay_chat);
|
||||||
progressView = fragmentView.findViewById(R.id.progressLayout);
|
progressView = fragmentView.findViewById(R.id.progressLayout);
|
||||||
pagedownButton = fragmentView.findViewById(R.id.pagedown_button);
|
pagedownButton = fragmentView.findViewById(R.id.pagedown_button);
|
||||||
pagedownButton.setVisibility(View.GONE);
|
pagedownButton.setVisibility(View.GONE);
|
||||||
@ -773,13 +773,8 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
TextView textView = (TextView)fragmentView.findViewById(R.id.bottom_overlay_chat_text);
|
bottomOverlayChatText = (TextView)fragmentView.findViewById(R.id.bottom_overlay_chat_text);
|
||||||
if (currentUser == null) {
|
TextView textView = (TextView)fragmentView.findViewById(R.id.secret_title);
|
||||||
textView.setText(LocaleController.getString("DeleteThisGroup", R.string.DeleteThisGroup));
|
|
||||||
} else {
|
|
||||||
textView.setText(LocaleController.getString("DeleteThisChat", R.string.DeleteThisChat));
|
|
||||||
}
|
|
||||||
textView = (TextView)fragmentView.findViewById(R.id.secret_title);
|
|
||||||
textView.setText(LocaleController.getString("EncryptedDescriptionTitle", R.string.EncryptedDescriptionTitle));
|
textView.setText(LocaleController.getString("EncryptedDescriptionTitle", R.string.EncryptedDescriptionTitle));
|
||||||
textView = (TextView)fragmentView.findViewById(R.id.secret_description1);
|
textView = (TextView)fragmentView.findViewById(R.id.secret_description1);
|
||||||
textView.setText(LocaleController.getString("EncryptedDescription1", R.string.EncryptedDescription1));
|
textView.setText(LocaleController.getString("EncryptedDescription1", R.string.EncryptedDescription1));
|
||||||
@ -816,8 +811,17 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
AlertDialog.Builder builder = new AlertDialog.Builder(getParentActivity());
|
AlertDialog.Builder builder = new AlertDialog.Builder(getParentActivity());
|
||||||
builder.setMessage(LocaleController.getString("AreYouSureDeleteThisChat", R.string.AreYouSureDeleteThisChat));
|
|
||||||
builder.setTitle(LocaleController.getString("AppName", R.string.AppName));
|
builder.setTitle(LocaleController.getString("AppName", R.string.AppName));
|
||||||
|
if (currentUser != null && userBlocked) {
|
||||||
|
builder.setMessage(LocaleController.getString("AreYouSureUnblockContact", R.string.AreYouSureUnblockContact));
|
||||||
|
builder.setPositiveButton(LocaleController.getString("OK", R.string.OK), new DialogInterface.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(DialogInterface dialogInterface, int i) {
|
||||||
|
MessagesController.getInstance().unblockUser(currentUser.id);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
builder.setMessage(LocaleController.getString("AreYouSureDeleteThisChat", R.string.AreYouSureDeleteThisChat));
|
||||||
builder.setPositiveButton(LocaleController.getString("OK", R.string.OK), new DialogInterface.OnClickListener() {
|
builder.setPositiveButton(LocaleController.getString("OK", R.string.OK), new DialogInterface.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(DialogInterface dialogInterface, int i) {
|
public void onClick(DialogInterface dialogInterface, int i) {
|
||||||
@ -825,6 +829,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
finishFragment();
|
finishFragment();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
}
|
||||||
builder.setNegativeButton(LocaleController.getString("Cancel", R.string.Cancel), null);
|
builder.setNegativeButton(LocaleController.getString("Cancel", R.string.Cancel), null);
|
||||||
showAlertDialog(builder);
|
showAlertDialog(builder);
|
||||||
}
|
}
|
||||||
@ -841,12 +846,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
if (currentChat != null && (currentChat instanceof TLRPC.TL_chatForbidden || currentChat.left) ||
|
updateBottomOverlay();
|
||||||
currentUser != null && (currentUser instanceof TLRPC.TL_userDeleted || currentUser instanceof TLRPC.TL_userEmpty)) {
|
|
||||||
bottomOverlayChat.setVisibility(View.VISIBLE);
|
|
||||||
} else {
|
|
||||||
bottomOverlayChat.setVisibility(View.GONE);
|
|
||||||
}
|
|
||||||
|
|
||||||
chatActivityEnterView.setContainerView(getParentActivity(), fragmentView);
|
chatActivityEnterView.setContainerView(getParentActivity(), fragmentView);
|
||||||
} else {
|
} else {
|
||||||
@ -892,7 +892,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
if (android.os.Build.VERSION.SDK_INT > 13 && animated) {
|
if (android.os.Build.VERSION.SDK_INT > 13 && animated) {
|
||||||
pagedownButton.setVisibility(View.VISIBLE);
|
pagedownButton.setVisibility(View.VISIBLE);
|
||||||
pagedownButton.setAlpha(0);
|
pagedownButton.setAlpha(0);
|
||||||
pagedownButton.animate().alpha(1).setDuration(200).start();
|
pagedownButton.animate().alpha(1).setDuration(200).setListener(null).start();
|
||||||
} else {
|
} else {
|
||||||
pagedownButton.setVisibility(View.VISIBLE);
|
pagedownButton.setVisibility(View.VISIBLE);
|
||||||
}
|
}
|
||||||
@ -1020,7 +1020,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
currentEncryptedChat.ttl = 60 * 60 * 24 * 7;
|
currentEncryptedChat.ttl = 60 * 60 * 24 * 7;
|
||||||
}
|
}
|
||||||
if (oldValue != currentEncryptedChat.ttl) {
|
if (oldValue != currentEncryptedChat.ttl) {
|
||||||
MessagesController.getInstance().sendTTLMessage(currentEncryptedChat);
|
SendMessagesHelper.getInstance().sendTTLMessage(currentEncryptedChat);
|
||||||
MessagesStorage.getInstance().updateEncryptedChat(currentEncryptedChat);
|
MessagesStorage.getInstance().updateEncryptedChat(currentEncryptedChat);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1073,7 +1073,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
onlineCount = 0;
|
onlineCount = 0;
|
||||||
int currentTime = ConnectionsManager.getInstance().getCurrentTime();
|
int currentTime = ConnectionsManager.getInstance().getCurrentTime();
|
||||||
for (TLRPC.TL_chatParticipant participant : info.participants) {
|
for (TLRPC.TL_chatParticipant participant : info.participants) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(participant.user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(participant.user_id);
|
||||||
if (user != null && user.status != null && (user.status.expires > currentTime || user.id == UserConfig.getClientUserId()) && user.status.expires > 10000) {
|
if (user != null && user.status != null && (user.status.expires > currentTime || user.id == UserConfig.getClientUserId()) && user.status.expires > 10000) {
|
||||||
onlineCount++;
|
onlineCount++;
|
||||||
}
|
}
|
||||||
@ -1084,9 +1084,9 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
|
|
||||||
private int getMessageType(MessageObject messageObject) {
|
private int getMessageType(MessageObject messageObject) {
|
||||||
if (currentEncryptedChat == null) {
|
if (currentEncryptedChat == null) {
|
||||||
boolean isBroadcastError = isBraodcast && messageObject.messageOwner.id <= 0 && messageObject.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SEND_ERROR;
|
boolean isBroadcastError = isBraodcast && messageObject.messageOwner.id <= 0 && messageObject.messageOwner.send_state == MessageObject.MESSAGE_SEND_STATE_SEND_ERROR;
|
||||||
if (!isBraodcast && messageObject.messageOwner.id <= 0 && messageObject.isOut() || isBroadcastError) {
|
if (!isBraodcast && messageObject.messageOwner.id <= 0 && messageObject.isOut() || isBroadcastError) {
|
||||||
if (messageObject.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SEND_ERROR) {
|
if (messageObject.messageOwner.send_state == MessageObject.MESSAGE_SEND_STATE_SEND_ERROR) {
|
||||||
if (!(messageObject.messageOwner.media instanceof TLRPC.TL_messageMediaEmpty)) {
|
if (!(messageObject.messageOwner.media instanceof TLRPC.TL_messageMediaEmpty)) {
|
||||||
return 0;
|
return 0;
|
||||||
} else {
|
} else {
|
||||||
@ -1140,13 +1140,13 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
} else {
|
} else {
|
||||||
if (messageObject.type == 7) {
|
if (messageObject.type == 7) {
|
||||||
return -1;
|
return -1;
|
||||||
} else if (messageObject.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SEND_ERROR) {
|
} else if (messageObject.messageOwner.send_state == MessageObject.MESSAGE_SEND_STATE_SEND_ERROR) {
|
||||||
if (!(messageObject.messageOwner.media instanceof TLRPC.TL_messageMediaEmpty)) {
|
if (!(messageObject.messageOwner.media instanceof TLRPC.TL_messageMediaEmpty)) {
|
||||||
return 0;
|
return 0;
|
||||||
} else {
|
} else {
|
||||||
return 6;
|
return 6;
|
||||||
}
|
}
|
||||||
} else if (messageObject.type == 10 || messageObject.type == 11 || messageObject.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SENDING) {
|
} else if (messageObject.type == 10 || messageObject.type == 11 || messageObject.messageOwner.send_state == MessageObject.MESSAGE_SEND_STATE_SENDING) {
|
||||||
if (messageObject.messageOwner.id == 0) {
|
if (messageObject.messageOwner.id == 0) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -1275,7 +1275,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (currentUser != null) {
|
} else if (currentUser != null) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(currentUser.id);
|
TLRPC.User user = MessagesController.getInstance().getUser(currentUser.id);
|
||||||
if (user != null) {
|
if (user != null) {
|
||||||
currentUser = user;
|
currentUser = user;
|
||||||
}
|
}
|
||||||
@ -1292,7 +1292,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
TLRPC.FileLocation newPhoto = null;
|
TLRPC.FileLocation newPhoto = null;
|
||||||
int placeHolderId = 0;
|
int placeHolderId = 0;
|
||||||
if (currentUser != null) {
|
if (currentUser != null) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(currentUser.id);
|
TLRPC.User user = MessagesController.getInstance().getUser(currentUser.id);
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1302,7 +1302,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
}
|
}
|
||||||
placeHolderId = Utilities.getUserAvatarForId(currentUser.id);
|
placeHolderId = Utilities.getUserAvatarForId(currentUser.id);
|
||||||
} else if (currentChat != null) {
|
} else if (currentChat != null) {
|
||||||
TLRPC.Chat chat = MessagesController.getInstance().chats.get(currentChat.id);
|
TLRPC.Chat chat = MessagesController.getInstance().getChat(currentChat.id);
|
||||||
if (chat == null) {
|
if (chat == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1504,10 +1504,10 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
if (photo != null) {
|
if (photo != null) {
|
||||||
final String originalPathFinal = originalPath;
|
final String originalPathFinal = originalPath;
|
||||||
final TLRPC.TL_photo photoFinal = photo;
|
final TLRPC.TL_photo photoFinal = photo;
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
MessagesController.getInstance().sendMessage(photoFinal, originalPathFinal, dialog_id);
|
SendMessagesHelper.getInstance().sendMessage(photoFinal, originalPathFinal, dialog_id);
|
||||||
if (chatListView != null) {
|
if (chatListView != null) {
|
||||||
chatListView.setSelectionFromTop(messages.size() - 1, -100000 - chatListView.getPaddingTop());
|
chatListView.setSelectionFromTop(messages.size() - 1, -100000 - chatListView.getPaddingTop());
|
||||||
}
|
}
|
||||||
@ -1575,9 +1575,9 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
}
|
}
|
||||||
if (document.mime_type.equals("image/gif")) {
|
if (document.mime_type.equals("image/gif")) {
|
||||||
try {
|
try {
|
||||||
Bitmap bitmap = FileLoader.loadBitmap(f.getAbsolutePath(), null, 90, 90);
|
Bitmap bitmap = ImageLoader.loadBitmap(f.getAbsolutePath(), null, 90, 90);
|
||||||
if (bitmap != null) {
|
if (bitmap != null) {
|
||||||
document.thumb = FileLoader.scaleAndSaveImage(bitmap, 90, 90, 55, currentEncryptedChat != null);
|
document.thumb = ImageLoader.scaleAndSaveImage(bitmap, 90, 90, 55, currentEncryptedChat != null);
|
||||||
document.thumb.type = "s";
|
document.thumb.type = "s";
|
||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
@ -1593,10 +1593,10 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
|
|
||||||
final TLRPC.TL_document documentFinal = document;
|
final TLRPC.TL_document documentFinal = document;
|
||||||
final String originalPathFinal = originalPath;
|
final String originalPathFinal = originalPath;
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
MessagesController.getInstance().sendMessage(documentFinal, originalPathFinal, dialog_id);
|
SendMessagesHelper.getInstance().sendMessage(documentFinal, originalPathFinal, dialog_id);
|
||||||
if (chatListView != null) {
|
if (chatListView != null) {
|
||||||
chatListView.setSelectionFromTop(messages.size() - 1, -100000 - chatListView.getPaddingTop());
|
chatListView.setSelectionFromTop(messages.size() - 1, -100000 - chatListView.getPaddingTop());
|
||||||
}
|
}
|
||||||
@ -1645,7 +1645,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
TLRPC.TL_video video = (TLRPC.TL_video)MessagesStorage.getInstance().getSentFile(originalPath, currentEncryptedChat == null ? 2 : 5);
|
TLRPC.TL_video video = (TLRPC.TL_video)MessagesStorage.getInstance().getSentFile(originalPath, currentEncryptedChat == null ? 2 : 5);
|
||||||
if (video == null) {
|
if (video == null) {
|
||||||
Bitmap thumb = ThumbnailUtils.createVideoThumbnail(videoPath, MediaStore.Video.Thumbnails.MINI_KIND);
|
Bitmap thumb = ThumbnailUtils.createVideoThumbnail(videoPath, MediaStore.Video.Thumbnails.MINI_KIND);
|
||||||
TLRPC.PhotoSize size = FileLoader.scaleAndSaveImage(thumb, 90, 90, 55, currentEncryptedChat != null);
|
TLRPC.PhotoSize size = ImageLoader.scaleAndSaveImage(thumb, 90, 90, 55, currentEncryptedChat != null);
|
||||||
if (size == null) {
|
if (size == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1674,10 +1674,10 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
|
|
||||||
final TLRPC.TL_video videoFinal = video;
|
final TLRPC.TL_video videoFinal = video;
|
||||||
final String originalPathFinal = originalPath;
|
final String originalPathFinal = originalPath;
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
MessagesController.getInstance().sendMessage(videoFinal, originalPathFinal, dialog_id);
|
SendMessagesHelper.getInstance().sendMessage(videoFinal, originalPathFinal, dialog_id);
|
||||||
if (chatListView != null) {
|
if (chatListView != null) {
|
||||||
chatListView.setSelectionFromTop(messages.size() - 1, -100000 - chatListView.getPaddingTop());
|
chatListView.setSelectionFromTop(messages.size() - 1, -100000 - chatListView.getPaddingTop());
|
||||||
}
|
}
|
||||||
@ -1707,7 +1707,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, final Object... args) {
|
public void didReceivedNotification(int id, final Object... args) {
|
||||||
if (id == MessagesController.messagesDidLoaded) {
|
if (id == NotificationCenter.messagesDidLoaded) {
|
||||||
long did = (Long)args[0];
|
long did = (Long)args[0];
|
||||||
if (did == dialog_id) {
|
if (did == dialog_id) {
|
||||||
int count = (Integer)args[1];
|
int count = (Integer)args[1];
|
||||||
@ -1924,11 +1924,11 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
progressView.setVisibility(View.GONE);
|
progressView.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == 999) {
|
} else if (id == NotificationCenter.emojiDidLoaded) {
|
||||||
if (chatListView != null) {
|
if (chatListView != null) {
|
||||||
chatListView.invalidateViews();
|
chatListView.invalidateViews();
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.updateInterfaces) {
|
} else if (id == NotificationCenter.updateInterfaces) {
|
||||||
int updateMask = (Integer)args[0];
|
int updateMask = (Integer)args[0];
|
||||||
if ((updateMask & MessagesController.UPDATE_MASK_NAME) != 0 || (updateMask & MessagesController.UPDATE_MASK_STATUS) != 0 || (updateMask & MessagesController.UPDATE_MASK_CHAT_NAME) != 0 || (updateMask & MessagesController.UPDATE_MASK_CHAT_MEMBERS) != 0) {
|
if ((updateMask & MessagesController.UPDATE_MASK_NAME) != 0 || (updateMask & MessagesController.UPDATE_MASK_STATUS) != 0 || (updateMask & MessagesController.UPDATE_MASK_CHAT_NAME) != 0 || (updateMask & MessagesController.UPDATE_MASK_CHAT_MEMBERS) != 0) {
|
||||||
updateSubtitle();
|
updateSubtitle();
|
||||||
@ -1947,7 +1947,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
if ((updateMask & MessagesController.UPDATE_MASK_USER_PHONE) != 0) {
|
if ((updateMask & MessagesController.UPDATE_MASK_USER_PHONE) != 0) {
|
||||||
updateContactStatus();
|
updateContactStatus();
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.didReceivedNewMessages) {
|
} else if (id == NotificationCenter.didReceivedNewMessages) {
|
||||||
long did = (Long)args[0];
|
long did = (Long)args[0];
|
||||||
if (did == dialog_id) {
|
if (did == dialog_id) {
|
||||||
|
|
||||||
@ -1966,7 +1966,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
if (currentEncryptedChat != null && obj.messageOwner.action != null && obj.messageOwner.action instanceof TLRPC.TL_messageActionTTLChange && timerButton != null) {
|
if (currentEncryptedChat != null && obj.messageOwner.action != null && obj.messageOwner.action instanceof TLRPC.TL_messageActionTTLChange && timerButton != null) {
|
||||||
timerButton.setTime(obj.messageOwner.action.ttl);
|
timerButton.setTime(obj.messageOwner.action.ttl);
|
||||||
}
|
}
|
||||||
if (obj.isOut() && obj.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SENDING) {
|
if (obj.isOut() && obj.messageOwner.send_state == MessageObject.MESSAGE_SEND_STATE_SENDING) {
|
||||||
scrollToLastMessage();
|
scrollToLastMessage();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -2108,9 +2108,9 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
checkAndUpdateAvatar();
|
checkAndUpdateAvatar();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.closeChats) {
|
} else if (id == NotificationCenter.closeChats) {
|
||||||
removeSelfFromStack();
|
removeSelfFromStack();
|
||||||
} else if (id == MessagesController.messagesReaded) {
|
} else if (id == NotificationCenter.messagesReaded) {
|
||||||
ArrayList<Integer> markAsReadMessages = (ArrayList<Integer>)args[0];
|
ArrayList<Integer> markAsReadMessages = (ArrayList<Integer>)args[0];
|
||||||
boolean updated = false;
|
boolean updated = false;
|
||||||
for (Integer ids : markAsReadMessages) {
|
for (Integer ids : markAsReadMessages) {
|
||||||
@ -2123,7 +2123,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
if (updated) {
|
if (updated) {
|
||||||
updateVisibleRows();
|
updateVisibleRows();
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.messagesDeleted) {
|
} else if (id == NotificationCenter.messagesDeleted) {
|
||||||
ArrayList<Integer> markAsDeletedMessages = (ArrayList<Integer>)args[0];
|
ArrayList<Integer> markAsDeletedMessages = (ArrayList<Integer>)args[0];
|
||||||
boolean updated = false;
|
boolean updated = false;
|
||||||
for (Integer ids : markAsDeletedMessages) {
|
for (Integer ids : markAsDeletedMessages) {
|
||||||
@ -2164,7 +2164,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
removeUnreadPlane(false);
|
removeUnreadPlane(false);
|
||||||
chatAdapter.notifyDataSetChanged();
|
chatAdapter.notifyDataSetChanged();
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.messageReceivedByServer) {
|
} else if (id == NotificationCenter.messageReceivedByServer) {
|
||||||
Integer msgId = (Integer)args[0];
|
Integer msgId = (Integer)args[0];
|
||||||
MessageObject obj = messagesDict.get(msgId);
|
MessageObject obj = messagesDict.get(msgId);
|
||||||
if (obj != null) {
|
if (obj != null) {
|
||||||
@ -2177,45 +2177,42 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
messagesDict.remove(msgId);
|
messagesDict.remove(msgId);
|
||||||
messagesDict.put(newMsgId, obj);
|
messagesDict.put(newMsgId, obj);
|
||||||
obj.messageOwner.id = newMsgId;
|
obj.messageOwner.id = newMsgId;
|
||||||
obj.messageOwner.send_state = MessagesController.MESSAGE_SEND_STATE_SENT;
|
obj.messageOwner.send_state = MessageObject.MESSAGE_SEND_STATE_SENT;
|
||||||
updateVisibleRows();
|
updateVisibleRows();
|
||||||
if (obj.messageOwner.attachPath != null && obj.messageOwner.attachPath.length() != 0) {
|
if (obj.messageOwner.attachPath != null && obj.messageOwner.attachPath.length() != 0) {
|
||||||
progressBarMap.remove(obj.messageOwner.attachPath);
|
progressBarMap.remove(obj.messageOwner.attachPath);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.messageReceivedByAck) {
|
} else if (id == NotificationCenter.messageReceivedByAck) {
|
||||||
Integer msgId = (Integer)args[0];
|
Integer msgId = (Integer)args[0];
|
||||||
MessageObject obj = messagesDict.get(msgId);
|
MessageObject obj = messagesDict.get(msgId);
|
||||||
if (obj != null) {
|
if (obj != null) {
|
||||||
if (obj.messageOwner.attachPath != null && obj.messageOwner.attachPath.length() != 0) {
|
if (obj.messageOwner.attachPath != null && obj.messageOwner.attachPath.length() != 0) {
|
||||||
progressBarMap.remove(obj.messageOwner.attachPath);
|
progressBarMap.remove(obj.messageOwner.attachPath);
|
||||||
}
|
}
|
||||||
obj.messageOwner.send_state = MessagesController.MESSAGE_SEND_STATE_SENT;
|
obj.messageOwner.send_state = MessageObject.MESSAGE_SEND_STATE_SENT;
|
||||||
updateVisibleRows();
|
updateVisibleRows();
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.messageSendError) {
|
} else if (id == NotificationCenter.messageSendError) {
|
||||||
Integer msgId = (Integer)args[0];
|
Integer msgId = (Integer)args[0];
|
||||||
MessageObject obj = messagesDict.get(msgId);
|
MessageObject obj = messagesDict.get(msgId);
|
||||||
if (obj != null) {
|
if (obj != null) {
|
||||||
obj.messageOwner.send_state = MessagesController.MESSAGE_SEND_STATE_SEND_ERROR;
|
obj.messageOwner.send_state = MessageObject.MESSAGE_SEND_STATE_SEND_ERROR;
|
||||||
updateVisibleRows();
|
updateVisibleRows();
|
||||||
if (obj.messageOwner.attachPath != null && obj.messageOwner.attachPath.length() != 0) {
|
if (obj.messageOwner.attachPath != null && obj.messageOwner.attachPath.length() != 0) {
|
||||||
progressBarMap.remove(obj.messageOwner.attachPath);
|
progressBarMap.remove(obj.messageOwner.attachPath);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == 997) {
|
} else if (id == NotificationCenter.chatInfoDidLoaded) {
|
||||||
MessagesController.getInstance().sendMessage((Double) args[0], (Double) args[1], dialog_id);
|
|
||||||
if (chatListView != null) {
|
|
||||||
chatListView.setSelectionFromTop(messages.size() - 1, -100000 - chatListView.getPaddingTop());
|
|
||||||
scrollToTopOnResume = true;
|
|
||||||
}
|
|
||||||
} else if (id == MessagesController.chatInfoDidLoaded) {
|
|
||||||
int chatId = (Integer)args[0];
|
int chatId = (Integer)args[0];
|
||||||
if (currentChat != null && chatId == currentChat.id) {
|
if (currentChat != null && chatId == currentChat.id) {
|
||||||
info = (TLRPC.ChatParticipants)args[1];
|
info = (TLRPC.ChatParticipants)args[1];
|
||||||
updateOnlineCount();
|
updateOnlineCount();
|
||||||
|
if (isBraodcast) {
|
||||||
|
SendMessagesHelper.getInstance().setCurrentChatInfo(info);
|
||||||
}
|
}
|
||||||
} else if (id == FileLoader.FileUploadProgressChanged) {
|
}
|
||||||
|
} else if (id == NotificationCenter.FileUploadProgressChanged) {
|
||||||
String location = (String)args[0];
|
String location = (String)args[0];
|
||||||
boolean enc = (Boolean)args[2];
|
boolean enc = (Boolean)args[2];
|
||||||
if (enc && currentEncryptedChat == null) {
|
if (enc && currentEncryptedChat == null) {
|
||||||
@ -2228,19 +2225,19 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
Float progress = (Float)args[1];
|
Float progress = (Float)args[1];
|
||||||
bar.setProgress((int) (progress * 100));
|
bar.setProgress((int) (progress * 100));
|
||||||
}
|
}
|
||||||
} else if (id == FileLoader.FileDidFailedLoad) {
|
} else if (id == NotificationCenter.FileDidFailedLoad) {
|
||||||
String location = (String)args[0];
|
String location = (String)args[0];
|
||||||
if (loadingFile.containsKey(location)) {
|
if (loadingFile.containsKey(location)) {
|
||||||
loadingFile.remove(location);
|
loadingFile.remove(location);
|
||||||
updateVisibleRows();
|
updateVisibleRows();
|
||||||
}
|
}
|
||||||
} else if (id == FileLoader.FileDidLoaded) {
|
} else if (id == NotificationCenter.FileDidLoaded) {
|
||||||
String location = (String)args[0];
|
String location = (String)args[0];
|
||||||
if (loadingFile.containsKey(location)) {
|
if (loadingFile.containsKey(location)) {
|
||||||
loadingFile.remove(location);
|
loadingFile.remove(location);
|
||||||
updateVisibleRows();
|
updateVisibleRows();
|
||||||
}
|
}
|
||||||
} else if (id == FileLoader.FileLoadProgressChanged) {
|
} else if (id == NotificationCenter.FileLoadProgressChanged) {
|
||||||
String location = (String)args[0];
|
String location = (String)args[0];
|
||||||
ArrayList<ProgressBar> arr = loadingFile.get(location);
|
ArrayList<ProgressBar> arr = loadingFile.get(location);
|
||||||
if (arr != null) {
|
if (arr != null) {
|
||||||
@ -2249,17 +2246,17 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
bar.setProgress((int)(progress * 100));
|
bar.setProgress((int)(progress * 100));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.contactsDidLoaded) {
|
} else if (id == NotificationCenter.contactsDidLoaded) {
|
||||||
updateContactStatus();
|
updateContactStatus();
|
||||||
updateSubtitle();
|
updateSubtitle();
|
||||||
} else if (id == MessagesController.encryptedChatUpdated) {
|
} else if (id == NotificationCenter.encryptedChatUpdated) {
|
||||||
TLRPC.EncryptedChat chat = (TLRPC.EncryptedChat)args[0];
|
TLRPC.EncryptedChat chat = (TLRPC.EncryptedChat)args[0];
|
||||||
if (currentEncryptedChat != null && chat.id == currentEncryptedChat.id) {
|
if (currentEncryptedChat != null && chat.id == currentEncryptedChat.id) {
|
||||||
currentEncryptedChat = chat;
|
currentEncryptedChat = chat;
|
||||||
updateContactStatus();
|
updateContactStatus();
|
||||||
updateSecretStatus();
|
updateSecretStatus();
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.messagesReadedEncrypted) {
|
} else if (id == NotificationCenter.messagesReadedEncrypted) {
|
||||||
int encId = (Integer)args[0];
|
int encId = (Integer)args[0];
|
||||||
if (currentEncryptedChat != null && currentEncryptedChat.id == encId) {
|
if (currentEncryptedChat != null && currentEncryptedChat.id == encId) {
|
||||||
int date = (Integer)args[1];
|
int date = (Integer)args[1];
|
||||||
@ -2276,7 +2273,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
}
|
}
|
||||||
updateVisibleRows();
|
updateVisibleRows();
|
||||||
}
|
}
|
||||||
} else if (id == MediaController.audioDidReset) {
|
} else if (id == NotificationCenter.audioDidReset) {
|
||||||
Integer mid = (Integer)args[0];
|
Integer mid = (Integer)args[0];
|
||||||
if (chatListView != null) {
|
if (chatListView != null) {
|
||||||
int count = chatListView.getChildCount();
|
int count = chatListView.getChildCount();
|
||||||
@ -2291,7 +2288,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == MediaController.audioProgressDidChanged) {
|
} else if (id == NotificationCenter.audioProgressDidChanged) {
|
||||||
Integer mid = (Integer)args[0];
|
Integer mid = (Integer)args[0];
|
||||||
if (chatListView != null) {
|
if (chatListView != null) {
|
||||||
int count = chatListView.getChildCount();
|
int count = chatListView.getChildCount();
|
||||||
@ -2306,7 +2303,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.removeAllMessagesFromDialog) {
|
} else if (id == NotificationCenter.removeAllMessagesFromDialog) {
|
||||||
messages.clear();
|
messages.clear();
|
||||||
messagesByDays.clear();
|
messagesByDays.clear();
|
||||||
messagesDict.clear();
|
messagesDict.clear();
|
||||||
@ -2329,8 +2326,35 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
selectedMessagesCanCopyIds.clear();
|
selectedMessagesCanCopyIds.clear();
|
||||||
actionBarLayer.hideActionMode();
|
actionBarLayer.hideActionMode();
|
||||||
chatAdapter.notifyDataSetChanged();
|
chatAdapter.notifyDataSetChanged();
|
||||||
} else if (id == MediaController.screenshotTook) {
|
} else if (id == NotificationCenter.screenshotTook) {
|
||||||
updateInformationForScreenshotDetector();
|
updateInformationForScreenshotDetector();
|
||||||
|
} else if (id == NotificationCenter.blockedUsersDidLoaded) {
|
||||||
|
if (currentUser != null) {
|
||||||
|
boolean oldValue = userBlocked;
|
||||||
|
userBlocked = MessagesController.getInstance().blockedUsers.contains(currentUser.id);
|
||||||
|
if (oldValue != userBlocked) {
|
||||||
|
updateBottomOverlay();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void updateBottomOverlay() {
|
||||||
|
if (currentUser == null) {
|
||||||
|
bottomOverlayChatText.setText(LocaleController.getString("DeleteThisGroup", R.string.DeleteThisGroup));
|
||||||
|
} else {
|
||||||
|
if (userBlocked) {
|
||||||
|
bottomOverlayChatText.setText(LocaleController.getString("Unblock", R.string.Unblock));
|
||||||
|
} else {
|
||||||
|
bottomOverlayChatText.setText(LocaleController.getString("DeleteThisChat", R.string.DeleteThisChat));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (currentChat != null && (currentChat instanceof TLRPC.TL_chatForbidden || currentChat.left) ||
|
||||||
|
currentUser != null && (currentUser instanceof TLRPC.TL_userDeleted || currentUser instanceof TLRPC.TL_userEmpty || userBlocked)) {
|
||||||
|
bottomOverlayChat.setVisibility(View.VISIBLE);
|
||||||
|
chatActivityEnterView.setFieldFocused(false);
|
||||||
|
} else {
|
||||||
|
bottomOverlayChat.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2341,7 +2365,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
if (currentUser == null) {
|
if (currentUser == null) {
|
||||||
topPanel.setVisibility(View.GONE);
|
topPanel.setVisibility(View.GONE);
|
||||||
} else {
|
} else {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(currentUser.id);
|
TLRPC.User user = MessagesController.getInstance().getUser(currentUser.id);
|
||||||
if (user != null) {
|
if (user != null) {
|
||||||
currentUser = user;
|
currentUser = user;
|
||||||
}
|
}
|
||||||
@ -2405,7 +2429,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
public void onClick(DialogInterface dialogInterface, int i) {
|
public void onClick(DialogInterface dialogInterface, int i) {
|
||||||
MessagesController.getInstance().hidenAddToContacts.put(currentUser.id, currentUser);
|
MessagesController.getInstance().hidenAddToContacts.put(currentUser.id, currentUser);
|
||||||
topPanel.setVisibility(View.GONE);
|
topPanel.setVisibility(View.GONE);
|
||||||
MessagesController.getInstance().sendMessage(UserConfig.getCurrentUser(), dialog_id);
|
SendMessagesHelper.getInstance().sendMessage(UserConfig.getCurrentUser(), dialog_id);
|
||||||
chatListView.post(new Runnable() {
|
chatListView.post(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
@ -2467,7 +2491,9 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
editor.commit();
|
editor.commit();
|
||||||
chatActivityEnterView.setFieldText(lastMessageText);
|
chatActivityEnterView.setFieldText(lastMessageText);
|
||||||
}
|
}
|
||||||
|
if (bottomOverlayChat.getVisibility() != View.VISIBLE) {
|
||||||
chatActivityEnterView.setFieldFocused(true);
|
chatActivityEnterView.setFieldFocused(true);
|
||||||
|
}
|
||||||
if (currentEncryptedChat != null) {
|
if (currentEncryptedChat != null) {
|
||||||
chatEnterTime = System.currentTimeMillis();
|
chatEnterTime = System.currentTimeMillis();
|
||||||
chatLeaveTime = 0;
|
chatLeaveTime = 0;
|
||||||
@ -2479,6 +2505,17 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
processSendingPhotos(photos, null);
|
processSendingPhotos(photos, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void didSelectLocation(double latitude, double longitude) {
|
||||||
|
SendMessagesHelper.getInstance().sendMessage(latitude, longitude, dialog_id);
|
||||||
|
if (chatListView != null) {
|
||||||
|
chatListView.setSelectionFromTop(messages.size() - 1, -100000 - chatListView.getPaddingTop());
|
||||||
|
}
|
||||||
|
if (paused) {
|
||||||
|
scrollToTopOnResume = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void startPhotoSelectActivity() {
|
public void startPhotoSelectActivity() {
|
||||||
try {
|
try {
|
||||||
@ -2795,50 +2832,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (option == 0) {
|
if (option == 0) {
|
||||||
if (selectedObject.messageOwner.id < 0) {
|
if (SendMessagesHelper.getInstance().retrySendMessage(selectedObject)) {
|
||||||
if (selectedObject.type == 0) {
|
|
||||||
if (selectedObject.messageOwner instanceof TLRPC.TL_messageForwarded) {
|
|
||||||
MessagesController.getInstance().sendMessage(selectedObject, dialog_id);
|
|
||||||
} else {
|
|
||||||
MessagesController.getInstance().sendMessage(selectedObject.messageOwner.message, dialog_id);
|
|
||||||
}
|
|
||||||
} else if (selectedObject.type == 4) {
|
|
||||||
MessagesController.getInstance().sendMessage(selectedObject.messageOwner.media.geo.lat, selectedObject.messageOwner.media.geo._long, dialog_id);
|
|
||||||
} else if (selectedObject.type == 1) {
|
|
||||||
if (selectedObject.messageOwner instanceof TLRPC.TL_messageForwarded) {
|
|
||||||
MessagesController.getInstance().sendMessage(selectedObject, dialog_id);
|
|
||||||
} else {
|
|
||||||
TLRPC.TL_photo photo = (TLRPC.TL_photo)selectedObject.messageOwner.media.photo;
|
|
||||||
MessagesController.getInstance().sendMessage(photo, selectedObject.messageOwner.attachPath, dialog_id);
|
|
||||||
}
|
|
||||||
} else if (selectedObject.type == 3) {
|
|
||||||
if (selectedObject.messageOwner instanceof TLRPC.TL_messageForwarded) {
|
|
||||||
MessagesController.getInstance().sendMessage(selectedObject, dialog_id);
|
|
||||||
} else {
|
|
||||||
TLRPC.TL_video video = (TLRPC.TL_video)selectedObject.messageOwner.media.video;
|
|
||||||
video.path = selectedObject.messageOwner.attachPath;
|
|
||||||
MessagesController.getInstance().sendMessage(video, video.path, dialog_id);
|
|
||||||
}
|
|
||||||
} else if (selectedObject.type == 12 || selectedObject.type == 13) {
|
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(selectedObject.messageOwner.media.user_id);
|
|
||||||
MessagesController.getInstance().sendMessage(user, dialog_id);
|
|
||||||
} else if (selectedObject.type == 8 || selectedObject.type == 9) {
|
|
||||||
TLRPC.TL_document document = (TLRPC.TL_document)selectedObject.messageOwner.media.document;
|
|
||||||
document.path = selectedObject.messageOwner.attachPath;
|
|
||||||
MessagesController.getInstance().sendMessage(document, document.path, dialog_id);
|
|
||||||
} else if (selectedObject.type == 2) {
|
|
||||||
TLRPC.TL_audio audio = (TLRPC.TL_audio)selectedObject.messageOwner.media.audio;
|
|
||||||
audio.path = selectedObject.messageOwner.attachPath;
|
|
||||||
MessagesController.getInstance().sendMessage(audio, dialog_id);
|
|
||||||
}
|
|
||||||
ArrayList<Integer> arr = new ArrayList<Integer>();
|
|
||||||
arr.add(selectedObject.messageOwner.id);
|
|
||||||
ArrayList<Long> random_ids = null;
|
|
||||||
if (currentEncryptedChat != null && selectedObject.messageOwner.random_id != 0 && selectedObject.type != 10) {
|
|
||||||
random_ids = new ArrayList<Long>();
|
|
||||||
random_ids.add(selectedObject.messageOwner.random_id);
|
|
||||||
}
|
|
||||||
MessagesController.getInstance().deleteMessages(arr, random_ids, currentEncryptedChat);
|
|
||||||
chatListView.setSelectionFromTop(messages.size() - 1, -100000 - chatListView.getPaddingTop());
|
chatListView.setSelectionFromTop(messages.size() - 1, -100000 - chatListView.getPaddingTop());
|
||||||
}
|
}
|
||||||
} else if (option == 1) {
|
} else if (option == 1) {
|
||||||
@ -2927,49 +2921,14 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void processForwardFromMe(MessageObject messageObject, long did) {
|
|
||||||
if (messageObject == null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (messageObject.messageOwner.media != null && !(messageObject.messageOwner.media instanceof TLRPC.TL_messageMediaEmpty)) {
|
|
||||||
if (messageObject.messageOwner.media.photo instanceof TLRPC.TL_photo) {
|
|
||||||
MessagesController.getInstance().sendMessage((TLRPC.TL_photo) messageObject.messageOwner.media.photo, null, did);
|
|
||||||
} else if (messageObject.messageOwner.media.audio instanceof TLRPC.TL_audio) {
|
|
||||||
messageObject.messageOwner.media.audio.path = messageObject.messageOwner.attachPath;
|
|
||||||
MessagesController.getInstance().sendMessage((TLRPC.TL_audio)messageObject.messageOwner.media.audio, did);
|
|
||||||
} else if (messageObject.messageOwner.media.video instanceof TLRPC.TL_video) {
|
|
||||||
messageObject.messageOwner.media.video.path = messageObject.messageOwner.attachPath;
|
|
||||||
MessagesController.getInstance().sendMessage((TLRPC.TL_video)messageObject.messageOwner.media.video, null, did);
|
|
||||||
} else if (messageObject.messageOwner.media.document instanceof TLRPC.TL_document) {
|
|
||||||
messageObject.messageOwner.media.document.path = messageObject.messageOwner.attachPath;
|
|
||||||
MessagesController.getInstance().sendMessage((TLRPC.TL_document)messageObject.messageOwner.media.document, null, did);
|
|
||||||
} else if (messageObject.messageOwner.media.geo instanceof TLRPC.TL_geoPoint) {
|
|
||||||
MessagesController.getInstance().sendMessage(messageObject.messageOwner.media.geo.lat, messageObject.messageOwner.media.geo._long, did);
|
|
||||||
} else if (messageObject.messageOwner.media.phone_number != null) {
|
|
||||||
TLRPC.User user = new TLRPC.TL_userContact();
|
|
||||||
user.phone = messageObject.messageOwner.media.phone_number;
|
|
||||||
user.first_name = messageObject.messageOwner.media.first_name;
|
|
||||||
user.last_name = messageObject.messageOwner.media.last_name;
|
|
||||||
user.id = messageObject.messageOwner.media.user_id;
|
|
||||||
MessagesController.getInstance().sendMessage(user, did);
|
|
||||||
} else {
|
|
||||||
MessagesController.getInstance().sendMessage(messageObject, did);
|
|
||||||
}
|
|
||||||
} else if (messageObject.messageOwner.message != null) {
|
|
||||||
MessagesController.getInstance().sendMessage(messageObject.messageOwner.message, did);
|
|
||||||
} else {
|
|
||||||
MessagesController.getInstance().sendMessage(messageObject, did);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void forwardSelectedMessages(long did, boolean fromMyName) {
|
private void forwardSelectedMessages(long did, boolean fromMyName) {
|
||||||
if (forwaringMessage != null) {
|
if (forwaringMessage != null) {
|
||||||
if (!fromMyName) {
|
if (!fromMyName) {
|
||||||
if (forwaringMessage.messageOwner.id > 0) {
|
if (forwaringMessage.messageOwner.id > 0) {
|
||||||
MessagesController.getInstance().sendMessage(forwaringMessage, did);
|
SendMessagesHelper.getInstance().sendMessage(forwaringMessage, did);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
processForwardFromMe(forwaringMessage, did);
|
SendMessagesHelper.getInstance().processForwardFromMyName(forwaringMessage, did);
|
||||||
}
|
}
|
||||||
forwaringMessage = null;
|
forwaringMessage = null;
|
||||||
} else {
|
} else {
|
||||||
@ -2978,10 +2937,10 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
for (Integer id : ids) {
|
for (Integer id : ids) {
|
||||||
if (!fromMyName) {
|
if (!fromMyName) {
|
||||||
if (id > 0) {
|
if (id > 0) {
|
||||||
MessagesController.getInstance().sendMessage(selectedMessagesIds.get(id), did);
|
SendMessagesHelper.getInstance().sendMessage(selectedMessagesIds.get(id), did);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
processForwardFromMe(selectedMessagesIds.get(id), did);
|
SendMessagesHelper.getInstance().processForwardFromMyName(selectedMessagesIds.get(id), did);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
selectedMessagesCanCopyIds.clear();
|
selectedMessagesCanCopyIds.clear();
|
||||||
@ -3319,7 +3278,6 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
view = new ChatMessageCell(mContext);
|
view = new ChatMessageCell(mContext);
|
||||||
} if (type == 1) {
|
} if (type == 1) {
|
||||||
view = new ChatMediaCell(mContext);
|
view = new ChatMediaCell(mContext);
|
||||||
((ChatMediaCell)view).downloadPhotos = downloadPhotos;
|
|
||||||
} else if (type == 10) {
|
} else if (type == 10) {
|
||||||
view = li.inflate(R.layout.chat_action_message_layout, viewGroup, false);
|
view = li.inflate(R.layout.chat_action_message_layout, viewGroup, false);
|
||||||
} else if (type == 11) {
|
} else if (type == 11) {
|
||||||
@ -3376,7 +3334,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
public void didPressedCancelSendButton(ChatBaseCell cell) {
|
public void didPressedCancelSendButton(ChatBaseCell cell) {
|
||||||
MessageObject message = cell.getMessageObject();
|
MessageObject message = cell.getMessageObject();
|
||||||
if (message.messageOwner.send_state != 0) {
|
if (message.messageOwner.send_state != 0) {
|
||||||
MessagesController.getInstance().cancelSendingMessage(message);
|
SendMessagesHelper.getInstance().cancelSendingMessage(message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3395,10 +3353,10 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
@Override
|
@Override
|
||||||
public void didPressedImage(ChatMediaCell cell) {
|
public void didPressedImage(ChatMediaCell cell) {
|
||||||
MessageObject message = cell.getMessageObject();
|
MessageObject message = cell.getMessageObject();
|
||||||
if (message.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SEND_ERROR) {
|
if (message.messageOwner.send_state == MessageObject.MESSAGE_SEND_STATE_SEND_ERROR) {
|
||||||
createMenu(cell, false);
|
createMenu(cell, false);
|
||||||
return;
|
return;
|
||||||
} else if (message.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SENDING) {
|
} else if (message.messageOwner.send_state == MessageObject.MESSAGE_SEND_STATE_SENDING) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (message.type == 1) {
|
if (message.type == 1) {
|
||||||
@ -3434,10 +3392,8 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
((ChatBaseCell)view).isChat = currentChat != null;
|
((ChatBaseCell)view).isChat = currentChat != null;
|
||||||
((ChatBaseCell)view).setMessageObject(message);
|
((ChatBaseCell)view).setMessageObject(message);
|
||||||
((ChatBaseCell)view).setCheckPressed(!disableSelection, disableSelection && selected);
|
((ChatBaseCell)view).setCheckPressed(!disableSelection, disableSelection && selected);
|
||||||
if (view instanceof ChatAudioCell && (downloadAudios == 0 || downloadAudios == 2 && ConnectionsManager.isConnectedToWiFi())) {
|
if (view instanceof ChatAudioCell && MediaController.getInstance().canDownloadMedia(MediaController.AUTODOWNLOAD_MASK_AUDIO)) {
|
||||||
((ChatAudioCell)view).downloadAudioIfNeed();
|
((ChatAudioCell)view).downloadAudioIfNeed(); //TODO
|
||||||
} else if (view instanceof ChatMediaCell) {
|
|
||||||
((ChatMediaCell)view).downloadPhotos = downloadPhotos;
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
ChatListRowHolderEx holder = (ChatListRowHolderEx)view.getTag();
|
ChatListRowHolderEx holder = (ChatListRowHolderEx)view.getTag();
|
||||||
@ -3517,7 +3473,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
private String photoFilter = null;
|
private String photoFilter = null;
|
||||||
|
|
||||||
public void update() {
|
public void update() {
|
||||||
TLRPC.User fromUser = MessagesController.getInstance().users.get(message.messageOwner.from_id);
|
TLRPC.User fromUser = MessagesController.getInstance().getUser(message.messageOwner.from_id);
|
||||||
|
|
||||||
int type = message.type;
|
int type = message.type;
|
||||||
|
|
||||||
@ -3562,7 +3518,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
photoImage.imageReceiver.setVisible(!PhotoViewer.getInstance().isShowingImage(message), false);
|
photoImage.imageReceiver.setVisible(!PhotoViewer.getInstance().isShowingImage(message), false);
|
||||||
}
|
}
|
||||||
} else if (type == 12 || type == 13) {
|
} else if (type == 12 || type == 13) {
|
||||||
TLRPC.User contactUser = MessagesController.getInstance().users.get(message.messageOwner.media.user_id);
|
TLRPC.User contactUser = MessagesController.getInstance().getUser(message.messageOwner.media.user_id);
|
||||||
if (contactUser != null) {
|
if (contactUser != null) {
|
||||||
nameTextView.setText(Utilities.formatName(message.messageOwner.media.first_name, message.messageOwner.media.last_name));
|
nameTextView.setText(Utilities.formatName(message.messageOwner.media.first_name, message.messageOwner.media.last_name));
|
||||||
nameTextView.setTextColor(Utilities.getColorForId(contactUser.id));
|
nameTextView.setTextColor(Utilities.getColorForId(contactUser.id));
|
||||||
@ -3648,15 +3604,9 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (message.messageOwner.id < 0 && message.messageOwner.send_state != MessagesController.MESSAGE_SEND_STATE_SEND_ERROR && message.messageOwner.send_state != MessagesController.MESSAGE_SEND_STATE_SENT) {
|
|
||||||
if (MessagesController.getInstance().sendingMessages.get(message.messageOwner.id) == null) {
|
|
||||||
message.messageOwner.send_state = MessagesController.MESSAGE_SEND_STATE_SEND_ERROR;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (message.isFromMe()) {
|
if (message.isFromMe()) {
|
||||||
if (halfCheckImage != null) {
|
if (halfCheckImage != null) {
|
||||||
if (message.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SENDING) {
|
if (message.messageOwner.send_state == MessageObject.MESSAGE_SEND_STATE_SENDING) {
|
||||||
checkImage.setVisibility(View.INVISIBLE);
|
checkImage.setVisibility(View.INVISIBLE);
|
||||||
halfCheckImage.setImageResource(R.drawable.msg_clock);
|
halfCheckImage.setImageResource(R.drawable.msg_clock);
|
||||||
halfCheckImage.setVisibility(View.VISIBLE);
|
halfCheckImage.setVisibility(View.VISIBLE);
|
||||||
@ -3666,7 +3616,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
}
|
}
|
||||||
Float progress = null;
|
Float progress = null;
|
||||||
if (message.messageOwner.attachPath != null && message.messageOwner.attachPath.length() != 0) {
|
if (message.messageOwner.attachPath != null && message.messageOwner.attachPath.length() != 0) {
|
||||||
progress = FileLoader.getInstance().fileProgresses.get(message.messageOwner.attachPath);
|
progress = FileLoader.getInstance().getFileProgress(message.messageOwner.attachPath);
|
||||||
progressByTag.put((Integer)actionProgress.getTag(), message.messageOwner.attachPath);
|
progressByTag.put((Integer)actionProgress.getTag(), message.messageOwner.attachPath);
|
||||||
progressBarMap.put(message.messageOwner.attachPath, actionProgress);
|
progressBarMap.put(message.messageOwner.attachPath, actionProgress);
|
||||||
}
|
}
|
||||||
@ -3679,7 +3629,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
if (actionAttachButton != null) {
|
if (actionAttachButton != null) {
|
||||||
actionAttachButton.setVisibility(View.GONE);
|
actionAttachButton.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
} else if (message.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SEND_ERROR) {
|
} else if (message.messageOwner.send_state == MessageObject.MESSAGE_SEND_STATE_SEND_ERROR) {
|
||||||
halfCheckImage.setVisibility(View.VISIBLE);
|
halfCheckImage.setVisibility(View.VISIBLE);
|
||||||
halfCheckImage.setImageResource(R.drawable.msg_warning);
|
halfCheckImage.setImageResource(R.drawable.msg_warning);
|
||||||
if (checkImage != null) {
|
if (checkImage != null) {
|
||||||
@ -3691,7 +3641,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
if (actionAttachButton != null) {
|
if (actionAttachButton != null) {
|
||||||
actionAttachButton.setVisibility(View.GONE);
|
actionAttachButton.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
} else if (message.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SENT) {
|
} else if (message.messageOwner.send_state == MessageObject.MESSAGE_SEND_STATE_SENT) {
|
||||||
if (!message.messageOwner.unread) {
|
if (!message.messageOwner.unread) {
|
||||||
halfCheckImage.setVisibility(View.VISIBLE);
|
halfCheckImage.setVisibility(View.VISIBLE);
|
||||||
checkImage.setVisibility(View.VISIBLE);
|
checkImage.setVisibility(View.VISIBLE);
|
||||||
@ -3716,7 +3666,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
if (file != null) {
|
if (file != null) {
|
||||||
removeFromloadingFile(file, actionProgress);
|
removeFromloadingFile(file, actionProgress);
|
||||||
}
|
}
|
||||||
if (message.messageOwner.send_state != MessagesController.MESSAGE_SEND_STATE_SENDING && message.messageOwner.send_state != MessagesController.MESSAGE_SEND_STATE_SEND_ERROR) {
|
if (message.messageOwner.send_state != MessageObject.MESSAGE_SEND_STATE_SENDING && message.messageOwner.send_state != MessageObject.MESSAGE_SEND_STATE_SEND_ERROR) {
|
||||||
if (file != null) {
|
if (file != null) {
|
||||||
progressBarMap.remove(file);
|
progressBarMap.remove(file);
|
||||||
}
|
}
|
||||||
@ -3756,7 +3706,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (load) {
|
if (load) {
|
||||||
Float progress = FileLoader.getInstance().fileProgresses.get(fileName);
|
Float progress = FileLoader.getInstance().getFileProgress(fileName);
|
||||||
if (loadingFile.containsKey(fileName) || progress != null) {
|
if (loadingFile.containsKey(fileName) || progress != null) {
|
||||||
if (progress != null) {
|
if (progress != null) {
|
||||||
actionProgress.setProgress((int)(progress * 100));
|
actionProgress.setProgress((int)(progress * 100));
|
||||||
@ -3890,7 +3840,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
if (message.messageOwner.media.user_id != UserConfig.getClientUserId()) {
|
if (message.messageOwner.media.user_id != UserConfig.getClientUserId()) {
|
||||||
TLRPC.User user = null;
|
TLRPC.User user = null;
|
||||||
if (message.messageOwner.media.user_id != 0) {
|
if (message.messageOwner.media.user_id != 0) {
|
||||||
user = MessagesController.getInstance().users.get(message.messageOwner.media.user_id);
|
user = MessagesController.getInstance().getUser(message.messageOwner.media.user_id);
|
||||||
}
|
}
|
||||||
if (user != null) {
|
if (user != null) {
|
||||||
Bundle args = new Bundle();
|
Bundle args = new Bundle();
|
||||||
@ -3987,7 +3937,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
if (message != null) {
|
if (message != null) {
|
||||||
Integer tag = (Integer)actionProgress.getTag();
|
Integer tag = (Integer)actionProgress.getTag();
|
||||||
if (message.messageOwner.send_state != 0) {
|
if (message.messageOwner.send_state != 0) {
|
||||||
MessagesController.getInstance().cancelSendingMessage(message);
|
SendMessagesHelper.getInstance().cancelSendingMessage(message);
|
||||||
String file = progressByTag.get(tag);
|
String file = progressByTag.get(tag);
|
||||||
if (file != null) {
|
if (file != null) {
|
||||||
progressBarMap.remove(file);
|
progressBarMap.remove(file);
|
||||||
@ -3997,7 +3947,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
if (file != null) {
|
if (file != null) {
|
||||||
loadingFile.remove(file);
|
loadingFile.remove(file);
|
||||||
if (message.type == 8 || message.type == 9) {
|
if (message.type == 8 || message.type == 9) {
|
||||||
FileLoader.getInstance().cancelLoadFile(null, null, message.messageOwner.media.document, null);
|
FileLoader.getInstance().cancelLoadFile(message.messageOwner.media.document);
|
||||||
}
|
}
|
||||||
updateVisibleRows();
|
updateVisibleRows();
|
||||||
}
|
}
|
||||||
@ -4076,17 +4026,17 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
|||||||
alertUserOpenError(message);
|
alertUserOpenError(message);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (message.messageOwner.send_state != MessagesController.MESSAGE_SEND_STATE_SEND_ERROR && message.messageOwner.send_state != MessagesController.MESSAGE_SEND_STATE_SENDING || !message.isOut()) {
|
if (message.messageOwner.send_state != MessageObject.MESSAGE_SEND_STATE_SEND_ERROR && message.messageOwner.send_state != MessageObject.MESSAGE_SEND_STATE_SENDING || !message.isOut()) {
|
||||||
if (!loadingFile.containsKey(fileName)) {
|
if (!loadingFile.containsKey(fileName)) {
|
||||||
progressByTag.put((Integer)actionProgress.getTag(), fileName);
|
progressByTag.put((Integer)actionProgress.getTag(), fileName);
|
||||||
addToLoadingFile(fileName, actionProgress);
|
addToLoadingFile(fileName, actionProgress);
|
||||||
if (message.type == 8 || message.type == 9) {
|
if (message.type == 8 || message.type == 9) {
|
||||||
FileLoader.getInstance().loadFile(null, null, message.messageOwner.media.document, null);
|
FileLoader.getInstance().loadFile(message.messageOwner.media.document);
|
||||||
}
|
}
|
||||||
updateVisibleRows();
|
updateVisibleRows();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (message.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SEND_ERROR) {
|
if (message.messageOwner.send_state == MessageObject.MESSAGE_SEND_STATE_SEND_ERROR) {
|
||||||
createMenu(view, false);
|
createMenu(view, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,11 +30,11 @@ import org.telegram.messenger.TLRPC;
|
|||||||
import org.telegram.messenger.ConnectionsManager;
|
import org.telegram.messenger.ConnectionsManager;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.objects.MessageObject;
|
import org.telegram.android.MessageObject;
|
||||||
import org.telegram.ui.Adapters.BaseFragmentAdapter;
|
import org.telegram.ui.Adapters.BaseFragmentAdapter;
|
||||||
import org.telegram.ui.Cells.ChatOrUserCell;
|
import org.telegram.ui.Cells.ChatOrUserCell;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
||||||
@ -84,7 +84,7 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
super.onFragmentCreate();
|
super.onFragmentCreate();
|
||||||
|
|
||||||
chat_id = getArguments().getInt("chat_id", 0);
|
chat_id = getArguments().getInt("chat_id", 0);
|
||||||
currentChat = MessagesController.getInstance().chats.get(chat_id);
|
currentChat = MessagesController.getInstance().getChat(chat_id);
|
||||||
if (currentChat == null) {
|
if (currentChat == null) {
|
||||||
final Semaphore semaphore = new Semaphore(0);
|
final Semaphore semaphore = new Semaphore(0);
|
||||||
MessagesStorage.getInstance().storageQueue.postRunnable(new Runnable() {
|
MessagesStorage.getInstance().storageQueue.postRunnable(new Runnable() {
|
||||||
@ -100,16 +100,16 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
if (currentChat != null) {
|
if (currentChat != null) {
|
||||||
MessagesController.getInstance().chats.put(currentChat.id, currentChat);
|
MessagesController.getInstance().putChat(currentChat, true);
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.updateInterfaces);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.chatInfoDidLoaded);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.chatInfoDidLoaded);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.mediaCountDidLoaded);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.mediaCountDidLoaded);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.closeChats);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.closeChats);
|
||||||
|
|
||||||
updateOnlineCount();
|
updateOnlineCount();
|
||||||
if (chat_id > 0) {
|
if (chat_id > 0) {
|
||||||
@ -162,10 +162,10 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
@Override
|
@Override
|
||||||
public void onFragmentDestroy() {
|
public void onFragmentDestroy() {
|
||||||
super.onFragmentDestroy();
|
super.onFragmentDestroy();
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.updateInterfaces);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.chatInfoDidLoaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.chatInfoDidLoaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.mediaCountDidLoaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.mediaCountDidLoaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.closeChats);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.closeChats);
|
||||||
avatarUpdater.clear();
|
avatarUpdater.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -302,7 +302,7 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
if (fileLocation == null) {
|
if (fileLocation == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
TLRPC.Chat chat = MessagesController.getInstance().chats.get(chat_id);
|
TLRPC.Chat chat = MessagesController.getInstance().getChat(chat_id);
|
||||||
if (chat != null && chat.photo != null && chat.photo.photo_big != null) {
|
if (chat != null && chat.photo != null && chat.photo.photo_big != null) {
|
||||||
TLRPC.FileLocation photoBig = chat.photo.photo_big;
|
TLRPC.FileLocation photoBig = chat.photo.photo_big;
|
||||||
if (photoBig.local_id == fileLocation.local_id && photoBig.volume_id == fileLocation.volume_id && photoBig.dc_id == fileLocation.dc_id) {
|
if (photoBig.local_id == fileLocation.local_id && photoBig.volume_id == fileLocation.volume_id && photoBig.dc_id == fileLocation.dc_id) {
|
||||||
@ -350,7 +350,7 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
public int getSelectedCount() { return 0; }
|
public int getSelectedCount() { return 0; }
|
||||||
|
|
||||||
public void didReceivedNotification(int id, Object... args) {
|
public void didReceivedNotification(int id, Object... args) {
|
||||||
if (id == MessagesController.updateInterfaces) {
|
if (id == NotificationCenter.updateInterfaces) {
|
||||||
int mask = (Integer)args[0];
|
int mask = (Integer)args[0];
|
||||||
if ((mask & MessagesController.UPDATE_MASK_CHAT_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_CHAT_NAME) != 0 || (mask & MessagesController.UPDATE_MASK_CHAT_MEMBERS) != 0 || (mask & MessagesController.UPDATE_MASK_STATUS) != 0) {
|
if ((mask & MessagesController.UPDATE_MASK_CHAT_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_CHAT_NAME) != 0 || (mask & MessagesController.UPDATE_MASK_CHAT_MEMBERS) != 0 || (mask & MessagesController.UPDATE_MASK_STATUS) != 0) {
|
||||||
updateOnlineCount();
|
updateOnlineCount();
|
||||||
@ -358,7 +358,7 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
if ((mask & MessagesController.UPDATE_MASK_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_NAME) != 0 || (mask & MessagesController.UPDATE_MASK_STATUS) != 0) {
|
if ((mask & MessagesController.UPDATE_MASK_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_NAME) != 0 || (mask & MessagesController.UPDATE_MASK_STATUS) != 0) {
|
||||||
updateVisibleRows(mask);
|
updateVisibleRows(mask);
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.chatInfoDidLoaded) {
|
} else if (id == NotificationCenter.chatInfoDidLoaded) {
|
||||||
int chatId = (Integer)args[0];
|
int chatId = (Integer)args[0];
|
||||||
if (chatId == chat_id) {
|
if (chatId == chat_id) {
|
||||||
info = (TLRPC.ChatParticipants)args[1];
|
info = (TLRPC.ChatParticipants)args[1];
|
||||||
@ -368,7 +368,7 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
listViewAdapter.notifyDataSetChanged();
|
listViewAdapter.notifyDataSetChanged();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.mediaCountDidLoaded) {
|
} else if (id == NotificationCenter.mediaCountDidLoaded) {
|
||||||
long uid = (Long)args[0];
|
long uid = (Long)args[0];
|
||||||
int lower_part = (int)uid;
|
int lower_part = (int)uid;
|
||||||
if (lower_part < 0 && chat_id == -lower_part) {
|
if (lower_part < 0 && chat_id == -lower_part) {
|
||||||
@ -377,7 +377,7 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
listView.invalidateViews();
|
listView.invalidateViews();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.closeChats) {
|
} else if (id == NotificationCenter.closeChats) {
|
||||||
removeSelfFromStack();
|
removeSelfFromStack();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -416,7 +416,7 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
sortedUsers.clear();
|
sortedUsers.clear();
|
||||||
int i = 0;
|
int i = 0;
|
||||||
for (TLRPC.TL_chatParticipant participant : info.participants) {
|
for (TLRPC.TL_chatParticipant participant : info.participants) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(participant.user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(participant.user_id);
|
||||||
if (user != null && user.status != null && (user.status.expires > currentTime || user.id == UserConfig.getClientUserId()) && user.status.expires > 10000) {
|
if (user != null && user.status != null && (user.status.expires > currentTime || user.id == UserConfig.getClientUserId()) && user.status.expires > 10000) {
|
||||||
onlineCount++;
|
onlineCount++;
|
||||||
}
|
}
|
||||||
@ -427,8 +427,8 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
Collections.sort(sortedUsers, new Comparator<Integer>() {
|
Collections.sort(sortedUsers, new Comparator<Integer>() {
|
||||||
@Override
|
@Override
|
||||||
public int compare(Integer lhs, Integer rhs) {
|
public int compare(Integer lhs, Integer rhs) {
|
||||||
TLRPC.User user1 = MessagesController.getInstance().users.get(info.participants.get(rhs).user_id);
|
TLRPC.User user1 = MessagesController.getInstance().getUser(info.participants.get(rhs).user_id);
|
||||||
TLRPC.User user2 = MessagesController.getInstance().users.get(info.participants.get(lhs).user_id);
|
TLRPC.User user2 = MessagesController.getInstance().getUser(info.participants.get(lhs).user_id);
|
||||||
Integer status1 = 0;
|
Integer status1 = 0;
|
||||||
Integer status2 = 0;
|
Integer status2 = 0;
|
||||||
if (user1 != null && user1.status != null) {
|
if (user1 != null && user1.status != null) {
|
||||||
@ -456,7 +456,7 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
|
|
||||||
private void processPhotoMenu(int action) {
|
private void processPhotoMenu(int action) {
|
||||||
if (action == 0) {
|
if (action == 0) {
|
||||||
TLRPC.Chat chat = MessagesController.getInstance().chats.get(chat_id);
|
TLRPC.Chat chat = MessagesController.getInstance().getChat(chat_id);
|
||||||
if (chat.photo != null && chat.photo.photo_big != null) {
|
if (chat.photo != null && chat.photo.photo_big != null) {
|
||||||
PhotoViewer.getInstance().setParentActivity(getParentActivity());
|
PhotoViewer.getInstance().setParentActivity(getParentActivity());
|
||||||
PhotoViewer.getInstance().openPhoto(chat.photo.photo_big, this);
|
PhotoViewer.getInstance().openPhoto(chat.photo.photo_big, this);
|
||||||
@ -493,11 +493,11 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
|
|
||||||
private void kickUser(TLRPC.TL_chatParticipant user) {
|
private void kickUser(TLRPC.TL_chatParticipant user) {
|
||||||
if (user != null) {
|
if (user != null) {
|
||||||
MessagesController.getInstance().deleteUserFromChat(chat_id, MessagesController.getInstance().users.get(user.user_id), info);
|
MessagesController.getInstance().deleteUserFromChat(chat_id, MessagesController.getInstance().getUser(user.user_id), info);
|
||||||
} else {
|
} else {
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.closeChats);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.closeChats);
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.closeChats);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.closeChats);
|
||||||
MessagesController.getInstance().deleteUserFromChat(chat_id, MessagesController.getInstance().users.get(UserConfig.getClientUserId()), info);
|
MessagesController.getInstance().deleteUserFromChat(chat_id, MessagesController.getInstance().getUser(UserConfig.getClientUserId()), info);
|
||||||
MessagesController.getInstance().deleteDialog(-chat_id, 0, false);
|
MessagesController.getInstance().deleteDialog(-chat_id, 0, false);
|
||||||
finishFragment();
|
finishFragment();
|
||||||
}
|
}
|
||||||
@ -546,7 +546,7 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
if (type == 0) {
|
if (type == 0) {
|
||||||
BackupImageView avatarImage;
|
BackupImageView avatarImage;
|
||||||
TextView onlineText;
|
TextView onlineText;
|
||||||
TLRPC.Chat chat = MessagesController.getInstance().chats.get(chat_id);
|
TLRPC.Chat chat = MessagesController.getInstance().getChat(chat_id);
|
||||||
if (view == null) {
|
if (view == null) {
|
||||||
LayoutInflater li = (LayoutInflater)mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
|
LayoutInflater li = (LayoutInflater)mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
|
||||||
view = li.inflate(R.layout.chat_profile_avatar_layout, viewGroup, false);
|
view = li.inflate(R.layout.chat_profile_avatar_layout, viewGroup, false);
|
||||||
@ -573,7 +573,7 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
AlertDialog.Builder builder = new AlertDialog.Builder(getParentActivity());
|
AlertDialog.Builder builder = new AlertDialog.Builder(getParentActivity());
|
||||||
CharSequence[] items;
|
CharSequence[] items;
|
||||||
int type;
|
int type;
|
||||||
TLRPC.Chat chat = MessagesController.getInstance().chats.get(chat_id);
|
TLRPC.Chat chat = MessagesController.getInstance().getChat(chat_id);
|
||||||
if (chat.photo == null || chat.photo.photo_big == null || chat.photo instanceof TLRPC.TL_chatPhotoEmpty) {
|
if (chat.photo == null || chat.photo.photo_big == null || chat.photo instanceof TLRPC.TL_chatPhotoEmpty) {
|
||||||
items = new CharSequence[]{LocaleController.getString("FromCamera", R.string.FromCamera), LocaleController.getString("FromGalley", R.string.FromGalley)};
|
items = new CharSequence[]{LocaleController.getString("FromCamera", R.string.FromCamera), LocaleController.getString("FromGalley", R.string.FromGalley)};
|
||||||
type = 0;
|
type = 0;
|
||||||
@ -655,7 +655,7 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
} else if (i == sharedMediaSectionRow) {
|
} else if (i == sharedMediaSectionRow) {
|
||||||
textView.setText(LocaleController.getString("SHAREDMEDIA", R.string.SHAREDMEDIA));
|
textView.setText(LocaleController.getString("SHAREDMEDIA", R.string.SHAREDMEDIA));
|
||||||
} else if (i == membersSectionRow) {
|
} else if (i == membersSectionRow) {
|
||||||
TLRPC.Chat chat = MessagesController.getInstance().chats.get(chat_id);
|
TLRPC.Chat chat = MessagesController.getInstance().getChat(chat_id);
|
||||||
int count = chat.participants_count;
|
int count = chat.participants_count;
|
||||||
if (info != null) {
|
if (info != null) {
|
||||||
count = info.participants.size();
|
count = info.participants.size();
|
||||||
@ -681,7 +681,7 @@ public class ChatProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
}
|
}
|
||||||
} else if (type == 3) {
|
} else if (type == 3) {
|
||||||
TLRPC.TL_chatParticipant part = info.participants.get(sortedUsers.get(i - membersSectionRow - 1));
|
TLRPC.TL_chatParticipant part = info.participants.get(sortedUsers.get(i - membersSectionRow - 1));
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(part.user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(part.user_id);
|
||||||
|
|
||||||
if (view == null) {
|
if (view == null) {
|
||||||
view = new ChatOrUserCell(mContext);
|
view = new ChatOrUserCell(mContext);
|
||||||
|
@ -73,7 +73,7 @@ public class ChatProfileChangeNameActivity extends BaseFragment {
|
|||||||
|
|
||||||
fragmentView = inflater.inflate(R.layout.chat_profile_change_name_layout, container, false);
|
fragmentView = inflater.inflate(R.layout.chat_profile_change_name_layout, container, false);
|
||||||
|
|
||||||
TLRPC.Chat currentChat = MessagesController.getInstance().chats.get(chat_id);
|
TLRPC.Chat currentChat = MessagesController.getInstance().getChat(chat_id);
|
||||||
|
|
||||||
firstNameField = (EditText)fragmentView.findViewById(R.id.first_name_field);
|
firstNameField = (EditText)fragmentView.findViewById(R.id.first_name_field);
|
||||||
if (chat_id > 0) {
|
if (chat_id > 0) {
|
||||||
|
@ -27,7 +27,7 @@ import org.telegram.android.ContactsController;
|
|||||||
import org.telegram.android.LocaleController;
|
import org.telegram.android.LocaleController;
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.ui.Views.BackupImageView;
|
import org.telegram.ui.Views.BackupImageView;
|
||||||
@ -49,17 +49,17 @@ public class ContactAddActivity extends BaseFragment implements NotificationCent
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onFragmentCreate() {
|
public boolean onFragmentCreate() {
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.updateInterfaces);
|
||||||
user_id = getArguments().getInt("user_id", 0);
|
user_id = getArguments().getInt("user_id", 0);
|
||||||
phone = getArguments().getString("phone");
|
phone = getArguments().getString("phone");
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(user_id);
|
||||||
return user != null && super.onFragmentCreate();
|
return user != null && super.onFragmentCreate();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onFragmentDestroy() {
|
public void onFragmentDestroy() {
|
||||||
super.onFragmentDestroy();
|
super.onFragmentDestroy();
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.updateInterfaces);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -78,12 +78,12 @@ public class ContactAddActivity extends BaseFragment implements NotificationCent
|
|||||||
@Override
|
@Override
|
||||||
public void onClick(View view) {
|
public void onClick(View view) {
|
||||||
if (firstNameField.getText().length() != 0) {
|
if (firstNameField.getText().length() != 0) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(user_id);
|
||||||
user.first_name = firstNameField.getText().toString();
|
user.first_name = firstNameField.getText().toString();
|
||||||
user.last_name = lastNameField.getText().toString();
|
user.last_name = lastNameField.getText().toString();
|
||||||
ContactsController.getInstance().addContact(user);
|
ContactsController.getInstance().addContact(user);
|
||||||
finishFragment();
|
finishFragment();
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.updateInterfaces, MessagesController.UPDATE_MASK_NAME);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.updateInterfaces, MessagesController.UPDATE_MASK_NAME);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -94,7 +94,7 @@ public class ContactAddActivity extends BaseFragment implements NotificationCent
|
|||||||
|
|
||||||
fragmentView = inflater.inflate(R.layout.contact_add_layout, container, false);
|
fragmentView = inflater.inflate(R.layout.contact_add_layout, container, false);
|
||||||
|
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(user_id);
|
||||||
if (user.phone == null) {
|
if (user.phone == null) {
|
||||||
if (phone != null) {
|
if (phone != null) {
|
||||||
user.phone = PhoneFormat.stripExceptNumbers(phone);
|
user.phone = PhoneFormat.stripExceptNumbers(phone);
|
||||||
@ -154,7 +154,7 @@ public class ContactAddActivity extends BaseFragment implements NotificationCent
|
|||||||
if (phoneText == null) {
|
if (phoneText == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(user_id);
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -169,7 +169,7 @@ public class ContactAddActivity extends BaseFragment implements NotificationCent
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void didReceivedNotification(int id, Object... args) {
|
public void didReceivedNotification(int id, Object... args) {
|
||||||
if (id == MessagesController.updateInterfaces) {
|
if (id == NotificationCenter.updateInterfaces) {
|
||||||
int mask = (Integer)args[0];
|
int mask = (Integer)args[0];
|
||||||
if ((mask & MessagesController.UPDATE_MASK_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_STATUS) != 0) {
|
if ((mask & MessagesController.UPDATE_MASK_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_STATUS) != 0) {
|
||||||
updateAvatarLayout();
|
updateAvatarLayout();
|
||||||
|
@ -35,7 +35,7 @@ import org.telegram.messenger.ConnectionsManager;
|
|||||||
import org.telegram.android.ContactsController;
|
import org.telegram.android.ContactsController;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.RPCRequest;
|
import org.telegram.messenger.RPCRequest;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
@ -86,9 +86,9 @@ public class ContactsActivity extends BaseFragment implements NotificationCenter
|
|||||||
@Override
|
@Override
|
||||||
public boolean onFragmentCreate() {
|
public boolean onFragmentCreate() {
|
||||||
super.onFragmentCreate();
|
super.onFragmentCreate();
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.contactsDidLoaded);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.contactsDidLoaded);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.updateInterfaces);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.encryptedChatCreated);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.encryptedChatCreated);
|
||||||
if (arguments != null) {
|
if (arguments != null) {
|
||||||
onlyUsers = getArguments().getBoolean("onlyUsers", false);
|
onlyUsers = getArguments().getBoolean("onlyUsers", false);
|
||||||
destroyAfterSelect = getArguments().getBoolean("destroyAfterSelect", false);
|
destroyAfterSelect = getArguments().getBoolean("destroyAfterSelect", false);
|
||||||
@ -111,9 +111,9 @@ public class ContactsActivity extends BaseFragment implements NotificationCenter
|
|||||||
@Override
|
@Override
|
||||||
public void onFragmentDestroy() {
|
public void onFragmentDestroy() {
|
||||||
super.onFragmentDestroy();
|
super.onFragmentDestroy();
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.contactsDidLoaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.contactsDidLoaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.updateInterfaces);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.encryptedChatCreated);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.encryptedChatCreated);
|
||||||
delegate = null;
|
delegate = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -242,7 +242,7 @@ public class ContactsActivity extends BaseFragment implements NotificationCenter
|
|||||||
ArrayList<TLRPC.TL_contact> arr = ContactsController.getInstance().usersSectionsDict.get(ContactsController.getInstance().sortedUsersSectionsArray.get(section));
|
ArrayList<TLRPC.TL_contact> arr = ContactsController.getInstance().usersSectionsDict.get(ContactsController.getInstance().sortedUsersSectionsArray.get(section));
|
||||||
if (row < arr.size()) {
|
if (row < arr.size()) {
|
||||||
TLRPC.TL_contact contact = arr.get(row);
|
TLRPC.TL_contact contact = arr.get(row);
|
||||||
user = MessagesController.getInstance().users.get(contact.user_id);
|
user = MessagesController.getInstance().getUser(contact.user_id);
|
||||||
} else {
|
} else {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -261,7 +261,7 @@ public class ContactsActivity extends BaseFragment implements NotificationCenter
|
|||||||
return;
|
return;
|
||||||
} else {
|
} else {
|
||||||
if (row - 1 < ContactsController.getInstance().contacts.size()) {
|
if (row - 1 < ContactsController.getInstance().contacts.size()) {
|
||||||
user = MessagesController.getInstance().users.get(ContactsController.getInstance().contacts.get(row - 1).user_id);
|
user = MessagesController.getInstance().getUser(ContactsController.getInstance().contacts.get(row - 1).user_id);
|
||||||
} else {
|
} else {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -396,16 +396,16 @@ public class ContactsActivity extends BaseFragment implements NotificationCenter
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, Object... args) {
|
public void didReceivedNotification(int id, Object... args) {
|
||||||
if (id == MessagesController.contactsDidLoaded) {
|
if (id == NotificationCenter.contactsDidLoaded) {
|
||||||
if (listViewAdapter != null) {
|
if (listViewAdapter != null) {
|
||||||
listViewAdapter.notifyDataSetChanged();
|
listViewAdapter.notifyDataSetChanged();
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.updateInterfaces) {
|
} else if (id == NotificationCenter.updateInterfaces) {
|
||||||
int mask = (Integer)args[0];
|
int mask = (Integer)args[0];
|
||||||
if ((mask & MessagesController.UPDATE_MASK_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_NAME) != 0 || (mask & MessagesController.UPDATE_MASK_STATUS) != 0) {
|
if ((mask & MessagesController.UPDATE_MASK_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_NAME) != 0 || (mask & MessagesController.UPDATE_MASK_STATUS) != 0) {
|
||||||
updateVisibleRows(mask);
|
updateVisibleRows(mask);
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.encryptedChatCreated) {
|
} else if (id == NotificationCenter.encryptedChatCreated) {
|
||||||
if (createSecretChat && creatingChat) {
|
if (createSecretChat && creatingChat) {
|
||||||
TLRPC.EncryptedChat encryptedChat = (TLRPC.EncryptedChat)args[0];
|
TLRPC.EncryptedChat encryptedChat = (TLRPC.EncryptedChat)args[0];
|
||||||
Bundle args2 = new Bundle();
|
Bundle args2 = new Bundle();
|
||||||
@ -429,7 +429,7 @@ public class ContactsActivity extends BaseFragment implements NotificationCenter
|
|||||||
if (error == null) {
|
if (error == null) {
|
||||||
final TLRPC.TL_help_inviteText res = (TLRPC.TL_help_inviteText)response;
|
final TLRPC.TL_help_inviteText res = (TLRPC.TL_help_inviteText)response;
|
||||||
if (res.message.length() != 0) {
|
if (res.message.length() != 0) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
updatingInviteText = false;
|
updatingInviteText = false;
|
||||||
|
@ -314,7 +314,7 @@ public class CountrySelectActivity extends BaseFragment {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void updateSearchResults(final ArrayList<Country> arrCounties) {
|
private void updateSearchResults(final ArrayList<Country> arrCounties) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
searchResult = arrCounties;
|
searchResult = arrCounties;
|
||||||
|
@ -40,7 +40,7 @@ import org.telegram.messenger.ConnectionsManager;
|
|||||||
import org.telegram.android.ContactsController;
|
import org.telegram.android.ContactsController;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
@ -119,18 +119,18 @@ public class GroupCreateActivity extends BaseFragment implements NotificationCen
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onFragmentCreate() {
|
public boolean onFragmentCreate() {
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.contactsDidLoaded);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.contactsDidLoaded);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.updateInterfaces);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.chatDidCreated);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.chatDidCreated);
|
||||||
return super.onFragmentCreate();
|
return super.onFragmentCreate();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onFragmentDestroy() {
|
public void onFragmentDestroy() {
|
||||||
super.onFragmentDestroy();
|
super.onFragmentDestroy();
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.contactsDidLoaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.contactsDidLoaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.updateInterfaces);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.chatDidCreated);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.chatDidCreated);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -262,7 +262,7 @@ public class GroupCreateActivity extends BaseFragment implements NotificationCen
|
|||||||
user = searchResult.get(row);
|
user = searchResult.get(row);
|
||||||
} else {
|
} else {
|
||||||
ArrayList<TLRPC.TL_contact> arr = ContactsController.getInstance().usersSectionsDict.get(ContactsController.getInstance().sortedUsersSectionsArray.get(section));
|
ArrayList<TLRPC.TL_contact> arr = ContactsController.getInstance().usersSectionsDict.get(ContactsController.getInstance().sortedUsersSectionsArray.get(section));
|
||||||
user = MessagesController.getInstance().users.get(arr.get(row).user_id);
|
user = MessagesController.getInstance().getUser(arr.get(row).user_id);
|
||||||
listView.invalidateViews();
|
listView.invalidateViews();
|
||||||
}
|
}
|
||||||
if (selectedContacts.containsKey(user.id)) {
|
if (selectedContacts.containsKey(user.id)) {
|
||||||
@ -395,7 +395,7 @@ public class GroupCreateActivity extends BaseFragment implements NotificationCen
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void processSearch(final String query) {
|
private void processSearch(final String query) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
final ArrayList<TLRPC.TL_contact> contactsCopy = new ArrayList<TLRPC.TL_contact>();
|
final ArrayList<TLRPC.TL_contact> contactsCopy = new ArrayList<TLRPC.TL_contact>();
|
||||||
@ -413,7 +413,7 @@ public class GroupCreateActivity extends BaseFragment implements NotificationCen
|
|||||||
String q = query.toLowerCase();
|
String q = query.toLowerCase();
|
||||||
|
|
||||||
for (TLRPC.TL_contact contact : contactsCopy) {
|
for (TLRPC.TL_contact contact : contactsCopy) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(contact.user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(contact.user_id);
|
||||||
if (user.first_name.toLowerCase().startsWith(q) || user.last_name.toLowerCase().startsWith(q)) {
|
if (user.first_name.toLowerCase().startsWith(q) || user.last_name.toLowerCase().startsWith(q)) {
|
||||||
if (user.id == UserConfig.getClientUserId()) {
|
if (user.id == UserConfig.getClientUserId()) {
|
||||||
continue;
|
continue;
|
||||||
@ -431,7 +431,7 @@ public class GroupCreateActivity extends BaseFragment implements NotificationCen
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void updateSearchResults(final ArrayList<TLRPC.User> users, final ArrayList<CharSequence> names) {
|
private void updateSearchResults(final ArrayList<TLRPC.User> users, final ArrayList<CharSequence> names) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
searchResult = users;
|
searchResult = users;
|
||||||
@ -443,19 +443,19 @@ public class GroupCreateActivity extends BaseFragment implements NotificationCen
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, Object... args) {
|
public void didReceivedNotification(int id, Object... args) {
|
||||||
if (id == MessagesController.contactsDidLoaded) {
|
if (id == NotificationCenter.contactsDidLoaded) {
|
||||||
if (listViewAdapter != null) {
|
if (listViewAdapter != null) {
|
||||||
listViewAdapter.notifyDataSetChanged();
|
listViewAdapter.notifyDataSetChanged();
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.updateInterfaces) {
|
} else if (id == NotificationCenter.updateInterfaces) {
|
||||||
int mask = (Integer)args[0];
|
int mask = (Integer)args[0];
|
||||||
if ((mask & MessagesController.UPDATE_MASK_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_NAME) != 0 || (mask & MessagesController.UPDATE_MASK_STATUS) != 0) {
|
if ((mask & MessagesController.UPDATE_MASK_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_NAME) != 0 || (mask & MessagesController.UPDATE_MASK_STATUS) != 0) {
|
||||||
if (listView != null) {
|
if (listView != null) {
|
||||||
listView.invalidateViews();
|
listView.invalidateViews();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.chatDidCreated) {
|
} else if (id == NotificationCenter.chatDidCreated) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
removeSelfFromStack();
|
removeSelfFromStack();
|
||||||
@ -504,11 +504,11 @@ public class GroupCreateActivity extends BaseFragment implements NotificationCen
|
|||||||
int size;
|
int size;
|
||||||
|
|
||||||
if (searchWas && searching) {
|
if (searchWas && searching) {
|
||||||
user = MessagesController.getInstance().users.get(searchResult.get(position).id);
|
user = MessagesController.getInstance().getUser(searchResult.get(position).id);
|
||||||
size = searchResult.size();
|
size = searchResult.size();
|
||||||
} else {
|
} else {
|
||||||
ArrayList<TLRPC.TL_contact> arr = ContactsController.getInstance().usersSectionsDict.get(ContactsController.getInstance().sortedUsersSectionsArray.get(section));
|
ArrayList<TLRPC.TL_contact> arr = ContactsController.getInstance().usersSectionsDict.get(ContactsController.getInstance().sortedUsersSectionsArray.get(section));
|
||||||
user = MessagesController.getInstance().users.get(arr.get(position).user_id);
|
user = MessagesController.getInstance().getUser(arr.get(position).user_id);
|
||||||
size = arr.size();
|
size = arr.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -21,15 +21,15 @@ import android.widget.EditText;
|
|||||||
import android.widget.ImageButton;
|
import android.widget.ImageButton;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
|
import org.telegram.android.AndroidUtilities;
|
||||||
import org.telegram.messenger.ConnectionsManager;
|
import org.telegram.messenger.ConnectionsManager;
|
||||||
import org.telegram.android.LocaleController;
|
import org.telegram.android.LocaleController;
|
||||||
import org.telegram.android.MessagesStorage;
|
import org.telegram.android.MessagesStorage;
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.Utilities;
|
|
||||||
import org.telegram.ui.Cells.ChatOrUserCell;
|
import org.telegram.ui.Cells.ChatOrUserCell;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarMenu;
|
import org.telegram.ui.Views.ActionBar.ActionBarMenu;
|
||||||
@ -66,15 +66,15 @@ public class GroupCreateFinalActivity extends BaseFragment implements Notificati
|
|||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
@Override
|
@Override
|
||||||
public boolean onFragmentCreate() {
|
public boolean onFragmentCreate() {
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.updateInterfaces);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.chatDidCreated);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.chatDidCreated);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.chatDidFailCreate);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.chatDidFailCreate);
|
||||||
avatarUpdater.parentFragment = this;
|
avatarUpdater.parentFragment = this;
|
||||||
avatarUpdater.delegate = this;
|
avatarUpdater.delegate = this;
|
||||||
selectedContacts = getArguments().getIntegerArrayList("result");
|
selectedContacts = getArguments().getIntegerArrayList("result");
|
||||||
final ArrayList<Integer> usersToLoad = new ArrayList<Integer>();
|
final ArrayList<Integer> usersToLoad = new ArrayList<Integer>();
|
||||||
for (Integer uid : selectedContacts) {
|
for (Integer uid : selectedContacts) {
|
||||||
if (MessagesController.getInstance().users.get(uid) == null) {
|
if (MessagesController.getInstance().getUser(uid) == null) {
|
||||||
usersToLoad.add(uid);
|
usersToLoad.add(uid);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -99,7 +99,7 @@ public class GroupCreateFinalActivity extends BaseFragment implements Notificati
|
|||||||
}
|
}
|
||||||
if (!users.isEmpty()) {
|
if (!users.isEmpty()) {
|
||||||
for (TLRPC.User user : users) {
|
for (TLRPC.User user : users) {
|
||||||
MessagesController.getInstance().users.putIfAbsent(user.id, user);
|
MessagesController.getInstance().putUser(user, true);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
@ -111,9 +111,9 @@ public class GroupCreateFinalActivity extends BaseFragment implements Notificati
|
|||||||
@Override
|
@Override
|
||||||
public void onFragmentDestroy() {
|
public void onFragmentDestroy() {
|
||||||
super.onFragmentDestroy();
|
super.onFragmentDestroy();
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.updateInterfaces);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.chatDidCreated);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.chatDidCreated);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.chatDidFailCreate);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.chatDidFailCreate);
|
||||||
avatarUpdater.clear();
|
avatarUpdater.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -247,7 +247,7 @@ public class GroupCreateFinalActivity extends BaseFragment implements Notificati
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void didUploadedPhoto(final TLRPC.InputFile file, final TLRPC.PhotoSize small, final TLRPC.PhotoSize big) {
|
public void didUploadedPhoto(final TLRPC.InputFile file, final TLRPC.PhotoSize small, final TLRPC.PhotoSize big) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
uploadedAvatar = file;
|
uploadedAvatar = file;
|
||||||
@ -296,12 +296,12 @@ public class GroupCreateFinalActivity extends BaseFragment implements Notificati
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, final Object... args) {
|
public void didReceivedNotification(int id, final Object... args) {
|
||||||
if (id == MessagesController.updateInterfaces) {
|
if (id == NotificationCenter.updateInterfaces) {
|
||||||
int mask = (Integer)args[0];
|
int mask = (Integer)args[0];
|
||||||
if ((mask & MessagesController.UPDATE_MASK_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_NAME) != 0 || (mask & MessagesController.UPDATE_MASK_STATUS) != 0) {
|
if ((mask & MessagesController.UPDATE_MASK_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_NAME) != 0 || (mask & MessagesController.UPDATE_MASK_STATUS) != 0) {
|
||||||
updateVisibleRows(mask);
|
updateVisibleRows(mask);
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.chatDidFailCreate) {
|
} else if (id == NotificationCenter.chatDidFailCreate) {
|
||||||
if (progressDialog != null) {
|
if (progressDialog != null) {
|
||||||
try {
|
try {
|
||||||
progressDialog.dismiss();
|
progressDialog.dismiss();
|
||||||
@ -310,8 +310,8 @@ public class GroupCreateFinalActivity extends BaseFragment implements Notificati
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
donePressed = false;
|
donePressed = false;
|
||||||
} else if (id == MessagesController.chatDidCreated) {
|
} else if (id == NotificationCenter.chatDidCreated) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
if (progressDialog != null) {
|
if (progressDialog != null) {
|
||||||
@ -384,7 +384,7 @@ public class GroupCreateFinalActivity extends BaseFragment implements Notificati
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public View getItemView(int section, int position, View convertView, ViewGroup parent) {
|
public View getItemView(int section, int position, View convertView, ViewGroup parent) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(selectedContacts.get(position));
|
TLRPC.User user = MessagesController.getInstance().getUser(selectedContacts.get(position));
|
||||||
|
|
||||||
if (convertView == null) {
|
if (convertView == null) {
|
||||||
convertView = new ChatOrUserCell(mContext);
|
convertView = new ChatOrUserCell(mContext);
|
||||||
|
@ -62,10 +62,10 @@ public class IdenticonActivity extends BaseFragment {
|
|||||||
fragmentView = inflater.inflate(R.layout.identicon_layout, container, false);
|
fragmentView = inflater.inflate(R.layout.identicon_layout, container, false);
|
||||||
IdenticonView identiconView = (IdenticonView) fragmentView.findViewById(R.id.identicon_view);
|
IdenticonView identiconView = (IdenticonView) fragmentView.findViewById(R.id.identicon_view);
|
||||||
TextView textView = (TextView)fragmentView.findViewById(R.id.identicon_text);
|
TextView textView = (TextView)fragmentView.findViewById(R.id.identicon_text);
|
||||||
TLRPC.EncryptedChat encryptedChat = MessagesController.getInstance().encryptedChats.get(chat_id);
|
TLRPC.EncryptedChat encryptedChat = MessagesController.getInstance().getEncryptedChat(chat_id);
|
||||||
if (encryptedChat != null) {
|
if (encryptedChat != null) {
|
||||||
identiconView.setBytes(encryptedChat.auth_key);
|
identiconView.setBytes(encryptedChat.auth_key);
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(encryptedChat.user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(encryptedChat.user_id);
|
||||||
textView.setText(Html.fromHtml(LocaleController.formatString("EncryptionKeyDescription", R.string.EncryptionKeyDescription, user.first_name, user.first_name)));
|
textView.setText(Html.fromHtml(LocaleController.formatString("EncryptionKeyDescription", R.string.EncryptionKeyDescription, user.first_name, user.first_name)));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -97,7 +97,7 @@ public class IdenticonActivity extends BaseFragment {
|
|||||||
if (fragmentView != null) {
|
if (fragmentView != null) {
|
||||||
fragmentView.getViewTreeObserver().removeOnPreDrawListener(this);
|
fragmentView.getViewTreeObserver().removeOnPreDrawListener(this);
|
||||||
}
|
}
|
||||||
if (getParentActivity() == null) {
|
if (getParentActivity() == null || fragmentView == null) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
LinearLayout layout = (LinearLayout)fragmentView;
|
LinearLayout layout = (LinearLayout)fragmentView;
|
||||||
|
@ -257,7 +257,7 @@ public class LanguageSelectActivity extends BaseFragment {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void updateSearchResults(final ArrayList<LocaleController.LocaleInfo> arrCounties) {
|
private void updateSearchResults(final ArrayList<LocaleController.LocaleInfo> arrCounties) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
searchResult = arrCounties;
|
searchResult = arrCounties;
|
||||||
|
@ -22,11 +22,12 @@ import android.widget.Toast;
|
|||||||
|
|
||||||
import org.telegram.android.AndroidUtilities;
|
import org.telegram.android.AndroidUtilities;
|
||||||
import org.telegram.PhoneFormat.PhoneFormat;
|
import org.telegram.PhoneFormat.PhoneFormat;
|
||||||
|
import org.telegram.android.SendMessagesHelper;
|
||||||
import org.telegram.messenger.ConnectionsManager;
|
import org.telegram.messenger.ConnectionsManager;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.android.LocaleController;
|
import org.telegram.android.LocaleController;
|
||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
@ -81,13 +82,12 @@ public class LaunchActivity extends ActionBarActivity implements NotificationCen
|
|||||||
AndroidUtilities.statusBarHeight = getResources().getDimensionPixelSize(resourceId);
|
AndroidUtilities.statusBarHeight = getResources().getDimensionPixelSize(resourceId);
|
||||||
}
|
}
|
||||||
|
|
||||||
NotificationCenter.getInstance().postNotificationName(702, this);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.closeOtherAppActivities, this);
|
||||||
currentConnectionState = ConnectionsManager.getInstance().getConnectionState();
|
currentConnectionState = ConnectionsManager.getInstance().getConnectionState();
|
||||||
|
|
||||||
NotificationCenter.getInstance().addObserver(this, 1234);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.appDidLogout);
|
||||||
NotificationCenter.getInstance().addObserver(this, 701);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.closeOtherAppActivities);
|
||||||
NotificationCenter.getInstance().addObserver(this, 702);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.didUpdatedConnectionState);
|
||||||
NotificationCenter.getInstance().addObserver(this, 703);
|
|
||||||
|
|
||||||
if (fragmentsStack.isEmpty()) {
|
if (fragmentsStack.isEmpty()) {
|
||||||
if (!UserConfig.isClientActivated()) {
|
if (!UserConfig.isClientActivated()) {
|
||||||
@ -344,7 +344,7 @@ public class LaunchActivity extends ActionBarActivity implements NotificationCen
|
|||||||
if (cursor != null) {
|
if (cursor != null) {
|
||||||
if (cursor.moveToFirst()) {
|
if (cursor.moveToFirst()) {
|
||||||
int userId = cursor.getInt(cursor.getColumnIndex("DATA4"));
|
int userId = cursor.getInt(cursor.getColumnIndex("DATA4"));
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.closeChats);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.closeChats);
|
||||||
push_user_id = userId;
|
push_user_id = userId;
|
||||||
}
|
}
|
||||||
cursor.close();
|
cursor.close();
|
||||||
@ -362,21 +362,21 @@ public class LaunchActivity extends ActionBarActivity implements NotificationCen
|
|||||||
int userId = intent.getIntExtra("userId", 0);
|
int userId = intent.getIntExtra("userId", 0);
|
||||||
int encId = intent.getIntExtra("encId", 0);
|
int encId = intent.getIntExtra("encId", 0);
|
||||||
if (chatId != 0) {
|
if (chatId != 0) {
|
||||||
TLRPC.Chat chat = MessagesController.getInstance().chats.get(chatId);
|
TLRPC.Chat chat = MessagesController.getInstance().getChat(chatId);
|
||||||
if (chat != null) {
|
if (chat != null) {
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.closeChats);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.closeChats);
|
||||||
push_chat_id = chatId;
|
push_chat_id = chatId;
|
||||||
}
|
}
|
||||||
} else if (userId != 0) {
|
} else if (userId != 0) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(userId);
|
TLRPC.User user = MessagesController.getInstance().getUser(userId);
|
||||||
if (user != null) {
|
if (user != null) {
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.closeChats);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.closeChats);
|
||||||
push_user_id = userId;
|
push_user_id = userId;
|
||||||
}
|
}
|
||||||
} else if (encId != 0) {
|
} else if (encId != 0) {
|
||||||
TLRPC.EncryptedChat chat = MessagesController.getInstance().encryptedChats.get(encId);
|
TLRPC.EncryptedChat chat = MessagesController.getInstance().getEncryptedChat(encId);
|
||||||
if (chat != null) {
|
if (chat != null) {
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.closeChats);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.closeChats);
|
||||||
push_enc_id = encId;
|
push_enc_id = encId;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -417,7 +417,7 @@ public class LaunchActivity extends ActionBarActivity implements NotificationCen
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (videoPath != null || photoPathsArray != null || sendingText != null || documentsPathsArray != null || contactsToSend != null) {
|
if (videoPath != null || photoPathsArray != null || sendingText != null || documentsPathsArray != null || contactsToSend != null) {
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.closeChats);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.closeChats);
|
||||||
Bundle args = new Bundle();
|
Bundle args = new Bundle();
|
||||||
args.putBoolean("onlySelect", true);
|
args.putBoolean("onlySelect", true);
|
||||||
args.putString("selectAlertString", LocaleController.getString("SendMessagesTo", R.string.SendMessagesTo));
|
args.putString("selectAlertString", LocaleController.getString("SendMessagesTo", R.string.SendMessagesTo));
|
||||||
@ -451,7 +451,7 @@ public class LaunchActivity extends ActionBarActivity implements NotificationCen
|
|||||||
|
|
||||||
Bundle args = new Bundle();
|
Bundle args = new Bundle();
|
||||||
args.putBoolean("scrollToTopOnResume", true);
|
args.putBoolean("scrollToTopOnResume", true);
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.closeChats);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.closeChats);
|
||||||
if (lower_part != 0) {
|
if (lower_part != 0) {
|
||||||
if (high_id == 1) {
|
if (high_id == 1) {
|
||||||
args.putInt("chat_id", lower_part);
|
args.putInt("chat_id", lower_part);
|
||||||
@ -481,7 +481,7 @@ public class LaunchActivity extends ActionBarActivity implements NotificationCen
|
|||||||
}
|
}
|
||||||
if (contactsToSend != null && !contactsToSend.isEmpty()) {
|
if (contactsToSend != null && !contactsToSend.isEmpty()) {
|
||||||
for (TLRPC.User user : contactsToSend) {
|
for (TLRPC.User user : contactsToSend) {
|
||||||
MessagesController.getInstance().sendMessage(user, dialog_id);
|
SendMessagesHelper.getInstance().sendMessage(user, dialog_id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -533,10 +533,9 @@ public class LaunchActivity extends ActionBarActivity implements NotificationCen
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
finished = true;
|
finished = true;
|
||||||
NotificationCenter.getInstance().removeObserver(this, 1234);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.appDidLogout);
|
||||||
NotificationCenter.getInstance().removeObserver(this, 701);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.closeOtherAppActivities);
|
||||||
NotificationCenter.getInstance().removeObserver(this, 702);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.didUpdatedConnectionState);
|
||||||
NotificationCenter.getInstance().removeObserver(this, 703);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -548,7 +547,7 @@ public class LaunchActivity extends ActionBarActivity implements NotificationCen
|
|||||||
@Override
|
@Override
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
public void didReceivedNotification(int id, Object... args) {
|
public void didReceivedNotification(int id, Object... args) {
|
||||||
if (id == 1234) {
|
if (id == NotificationCenter.appDidLogout) {
|
||||||
for (BaseFragment fragment : fragmentsStack) {
|
for (BaseFragment fragment : fragmentsStack) {
|
||||||
fragment.onFragmentDestroy();
|
fragment.onFragmentDestroy();
|
||||||
}
|
}
|
||||||
@ -557,11 +556,11 @@ public class LaunchActivity extends ActionBarActivity implements NotificationCen
|
|||||||
startActivity(intent2);
|
startActivity(intent2);
|
||||||
onFinish();
|
onFinish();
|
||||||
finish();
|
finish();
|
||||||
} else if (id == 702) {
|
} else if (id == NotificationCenter.closeOtherAppActivities) {
|
||||||
if (args[0] != this) {
|
if (args[0] != this) {
|
||||||
onFinish();
|
onFinish();
|
||||||
}
|
}
|
||||||
} else if (id == 703) {
|
} else if (id == NotificationCenter.didUpdatedConnectionState) {
|
||||||
int state = (Integer)args[0];
|
int state = (Integer)args[0];
|
||||||
if (currentConnectionState != state) {
|
if (currentConnectionState != state) {
|
||||||
FileLog.e("tmessages", "switch to state " + state);
|
FileLog.e("tmessages", "switch to state " + state);
|
||||||
|
@ -30,9 +30,9 @@ import com.google.android.gms.maps.model.MarkerOptions;
|
|||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.android.LocaleController;
|
import org.telegram.android.LocaleController;
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.objects.MessageObject;
|
import org.telegram.android.MessageObject;
|
||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
||||||
@ -55,19 +55,24 @@ public class LocationActivity extends BaseFragment implements NotificationCenter
|
|||||||
private boolean userLocationMoved = false;
|
private boolean userLocationMoved = false;
|
||||||
private boolean firstWas = false;
|
private boolean firstWas = false;
|
||||||
private MapView mapView;
|
private MapView mapView;
|
||||||
|
private LocationActivityDelegate delegate;
|
||||||
|
|
||||||
private final static int map_to_my_location = 1;
|
private final static int map_to_my_location = 1;
|
||||||
private final static int map_list_menu_map = 2;
|
private final static int map_list_menu_map = 2;
|
||||||
private final static int map_list_menu_satellite = 3;
|
private final static int map_list_menu_satellite = 3;
|
||||||
private final static int map_list_menu_hybrid = 4;
|
private final static int map_list_menu_hybrid = 4;
|
||||||
|
|
||||||
|
public static interface LocationActivityDelegate {
|
||||||
|
public abstract void didSelectLocation(double latitude, double longitude);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onFragmentCreate() {
|
public boolean onFragmentCreate() {
|
||||||
super.onFragmentCreate();
|
super.onFragmentCreate();
|
||||||
swipeBackEnabled = false;
|
swipeBackEnabled = false;
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.closeChats);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.closeChats);
|
||||||
if (messageObject != null) {
|
if (messageObject != null) {
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.updateInterfaces);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -75,8 +80,8 @@ public class LocationActivity extends BaseFragment implements NotificationCenter
|
|||||||
@Override
|
@Override
|
||||||
public void onFragmentDestroy() {
|
public void onFragmentDestroy() {
|
||||||
super.onFragmentDestroy();
|
super.onFragmentDestroy();
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.updateInterfaces);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.closeChats);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.closeChats);
|
||||||
if (mapView != null) {
|
if (mapView != null) {
|
||||||
mapView.onDestroy();
|
mapView.onDestroy();
|
||||||
}
|
}
|
||||||
@ -180,7 +185,9 @@ public class LocationActivity extends BaseFragment implements NotificationCenter
|
|||||||
sendButton.setOnClickListener(new View.OnClickListener() {
|
sendButton.setOnClickListener(new View.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(View view) {
|
public void onClick(View view) {
|
||||||
NotificationCenter.getInstance().postNotificationName(997, userLocation.getLatitude(), userLocation.getLongitude());
|
if (delegate != null) {
|
||||||
|
delegate.didSelectLocation(userLocation.getLatitude(), userLocation.getLongitude());
|
||||||
|
}
|
||||||
finishFragment();
|
finishFragment();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -222,7 +229,7 @@ public class LocationActivity extends BaseFragment implements NotificationCenter
|
|||||||
if (messageObject.messageOwner instanceof TLRPC.TL_messageForwarded) {
|
if (messageObject.messageOwner instanceof TLRPC.TL_messageForwarded) {
|
||||||
fromId = messageObject.messageOwner.fwd_from_id;
|
fromId = messageObject.messageOwner.fwd_from_id;
|
||||||
}
|
}
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(fromId);
|
TLRPC.User user = MessagesController.getInstance().getUser(fromId);
|
||||||
if (user != null) {
|
if (user != null) {
|
||||||
TLRPC.FileLocation photo = null;
|
TLRPC.FileLocation photo = null;
|
||||||
if (user.photo != null) {
|
if (user.photo != null) {
|
||||||
@ -271,7 +278,7 @@ public class LocationActivity extends BaseFragment implements NotificationCenter
|
|||||||
if (messageObject.messageOwner instanceof TLRPC.TL_messageForwarded) {
|
if (messageObject.messageOwner instanceof TLRPC.TL_messageForwarded) {
|
||||||
fromId = messageObject.messageOwner.fwd_from_id;
|
fromId = messageObject.messageOwner.fwd_from_id;
|
||||||
}
|
}
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(fromId);
|
TLRPC.User user = MessagesController.getInstance().getUser(fromId);
|
||||||
if (user != null) {
|
if (user != null) {
|
||||||
TLRPC.FileLocation photo = null;
|
TLRPC.FileLocation photo = null;
|
||||||
if (user.photo != null) {
|
if (user.photo != null) {
|
||||||
@ -320,12 +327,12 @@ public class LocationActivity extends BaseFragment implements NotificationCenter
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, Object... args) {
|
public void didReceivedNotification(int id, Object... args) {
|
||||||
if (id == MessagesController.updateInterfaces) {
|
if (id == NotificationCenter.updateInterfaces) {
|
||||||
int mask = (Integer)args[0];
|
int mask = (Integer)args[0];
|
||||||
if ((mask & MessagesController.UPDATE_MASK_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_NAME) != 0) {
|
if ((mask & MessagesController.UPDATE_MASK_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_NAME) != 0) {
|
||||||
updateUserData();
|
updateUserData();
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.closeChats) {
|
} else if (id == NotificationCenter.closeChats) {
|
||||||
removeSelfFromStack();
|
removeSelfFromStack();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -357,4 +364,8 @@ public class LocationActivity extends BaseFragment implements NotificationCenter
|
|||||||
mapView.onLowMemory();
|
mapView.onLowMemory();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setDelegate(LocationActivityDelegate delegate) {
|
||||||
|
this.delegate = delegate;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -355,7 +355,7 @@ public class LoginActivityPhoneView extends SlideView implements AdapterView.OnI
|
|||||||
ConnectionsManager.getInstance().performRpc(req, new RPCRequest.RPCRequestDelegate() {
|
ConnectionsManager.getInstance().performRpc(req, new RPCRequest.RPCRequestDelegate() {
|
||||||
@Override
|
@Override
|
||||||
public void run(final TLObject response, final TLRPC.TL_error error) {
|
public void run(final TLObject response, final TLRPC.TL_error error) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
nextPressed = false;
|
nextPressed = false;
|
||||||
|
@ -17,6 +17,7 @@ import android.view.inputmethod.EditorInfo;
|
|||||||
import android.widget.EditText;
|
import android.widget.EditText;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
|
import org.telegram.android.AndroidUtilities;
|
||||||
import org.telegram.android.LocaleController;
|
import org.telegram.android.LocaleController;
|
||||||
import org.telegram.messenger.TLObject;
|
import org.telegram.messenger.TLObject;
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
@ -27,7 +28,6 @@ import org.telegram.android.MessagesStorage;
|
|||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.RPCRequest;
|
import org.telegram.messenger.RPCRequest;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
import org.telegram.messenger.Utilities;
|
|
||||||
import org.telegram.ui.Views.SlideView;
|
import org.telegram.ui.Views.SlideView;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
@ -139,7 +139,7 @@ public class LoginActivityRegisterView extends SlideView {
|
|||||||
ConnectionsManager.getInstance().performRpc(req, new RPCRequest.RPCRequestDelegate() {
|
ConnectionsManager.getInstance().performRpc(req, new RPCRequest.RPCRequestDelegate() {
|
||||||
@Override
|
@Override
|
||||||
public void run(final TLObject response, final TLRPC.TL_error error) {
|
public void run(final TLObject response, final TLRPC.TL_error error) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
nextPressed = false;
|
nextPressed = false;
|
||||||
@ -158,8 +158,9 @@ public class LoginActivityRegisterView extends SlideView {
|
|||||||
users.add(user);
|
users.add(user);
|
||||||
MessagesStorage.getInstance().putUsersAndChats(users, null, true, true);
|
MessagesStorage.getInstance().putUsersAndChats(users, null, true, true);
|
||||||
//MessagesController.getInstance().uploadAndApplyUserAvatar(avatarPhotoBig);
|
//MessagesController.getInstance().uploadAndApplyUserAvatar(avatarPhotoBig);
|
||||||
MessagesController.getInstance().users.put(res.user.id, res.user);
|
MessagesController.getInstance().putUser(res.user, false);
|
||||||
ContactsController.getInstance().checkAppAccount();
|
ContactsController.getInstance().checkAppAccount();
|
||||||
|
MessagesController.getInstance().getBlockedUsers(true);
|
||||||
if (delegate != null) {
|
if (delegate != null) {
|
||||||
delegate.needFinishActivity();
|
delegate.needFinishActivity();
|
||||||
}
|
}
|
||||||
|
@ -31,7 +31,7 @@ import org.telegram.android.ContactsController;
|
|||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
import org.telegram.android.MessagesStorage;
|
import org.telegram.android.MessagesStorage;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.RPCRequest;
|
import org.telegram.messenger.RPCRequest;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
@ -187,7 +187,7 @@ public class LoginActivitySmsView extends SlideView implements NotificationCente
|
|||||||
double diff = currentTime - lastCodeTime;
|
double diff = currentTime - lastCodeTime;
|
||||||
codeTime -= diff;
|
codeTime -= diff;
|
||||||
lastCodeTime = currentTime;
|
lastCodeTime = currentTime;
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
if (codeTime <= 1000) {
|
if (codeTime <= 1000) {
|
||||||
@ -225,7 +225,7 @@ public class LoginActivitySmsView extends SlideView implements NotificationCente
|
|||||||
double diff = currentTime - lastCurrentTime;
|
double diff = currentTime - lastCurrentTime;
|
||||||
time -= diff;
|
time -= diff;
|
||||||
lastCurrentTime = currentTime;
|
lastCurrentTime = currentTime;
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
if (time >= 1000) {
|
if (time >= 1000) {
|
||||||
@ -243,7 +243,7 @@ public class LoginActivitySmsView extends SlideView implements NotificationCente
|
|||||||
@Override
|
@Override
|
||||||
public void run(TLObject response, final TLRPC.TL_error error) {
|
public void run(TLObject response, final TLRPC.TL_error error) {
|
||||||
if (error != null && error.text != null) {
|
if (error != null && error.text != null) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
lastError = error.text;
|
lastError = error.text;
|
||||||
@ -292,7 +292,7 @@ public class LoginActivitySmsView extends SlideView implements NotificationCente
|
|||||||
ConnectionsManager.getInstance().performRpc(req, new RPCRequest.RPCRequestDelegate() {
|
ConnectionsManager.getInstance().performRpc(req, new RPCRequest.RPCRequestDelegate() {
|
||||||
@Override
|
@Override
|
||||||
public void run(final TLObject response, final TLRPC.TL_error error) {
|
public void run(final TLObject response, final TLRPC.TL_error error) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
if (delegate == null) {
|
if (delegate == null) {
|
||||||
@ -312,8 +312,9 @@ public class LoginActivitySmsView extends SlideView implements NotificationCente
|
|||||||
ArrayList<TLRPC.User> users = new ArrayList<TLRPC.User>();
|
ArrayList<TLRPC.User> users = new ArrayList<TLRPC.User>();
|
||||||
users.add(res.user);
|
users.add(res.user);
|
||||||
MessagesStorage.getInstance().putUsersAndChats(users, null, true, true);
|
MessagesStorage.getInstance().putUsersAndChats(users, null, true, true);
|
||||||
MessagesController.getInstance().users.put(res.user.id, res.user);
|
MessagesController.getInstance().putUser(res.user, false);
|
||||||
ContactsController.getInstance().checkAppAccount();
|
ContactsController.getInstance().checkAppAccount();
|
||||||
|
MessagesController.getInstance().getBlockedUsers(true);
|
||||||
delegate.needFinishActivity();
|
delegate.needFinishActivity();
|
||||||
ConnectionsManager.getInstance().initPushConnection();
|
ConnectionsManager.getInstance().initPushConnection();
|
||||||
} else {
|
} else {
|
||||||
@ -379,7 +380,7 @@ public class LoginActivitySmsView extends SlideView implements NotificationCente
|
|||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, final Object... args) {
|
public void didReceivedNotification(int id, final Object... args) {
|
||||||
if (id == 998) {
|
if (id == 998) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
if (!waitingForSms) {
|
if (!waitingForSms) {
|
||||||
|
@ -26,11 +26,11 @@ import android.widget.TextView;
|
|||||||
import org.telegram.android.AndroidUtilities;
|
import org.telegram.android.AndroidUtilities;
|
||||||
import org.telegram.android.LocaleController;
|
import org.telegram.android.LocaleController;
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.objects.MessageObject;
|
import org.telegram.android.MessageObject;
|
||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.objects.PhotoObject;
|
import org.telegram.android.PhotoObject;
|
||||||
import org.telegram.ui.Adapters.BaseFragmentAdapter;
|
import org.telegram.ui.Adapters.BaseFragmentAdapter;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
||||||
import org.telegram.ui.Views.BackupImageView;
|
import org.telegram.ui.Views.BackupImageView;
|
||||||
@ -61,10 +61,10 @@ public class MediaActivity extends BaseFragment implements NotificationCenter.No
|
|||||||
@Override
|
@Override
|
||||||
public boolean onFragmentCreate() {
|
public boolean onFragmentCreate() {
|
||||||
super.onFragmentCreate();
|
super.onFragmentCreate();
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.mediaDidLoaded);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.mediaDidLoaded);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.messagesDeleted);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.messagesDeleted);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.didReceivedNewMessages);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.didReceivedNewMessages);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.messageReceivedByServer);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.messageReceivedByServer);
|
||||||
dialog_id = getArguments().getLong("dialog_id", 0);
|
dialog_id = getArguments().getLong("dialog_id", 0);
|
||||||
if (((int)dialog_id) == 0) {
|
if (((int)dialog_id) == 0) {
|
||||||
max_id = Integer.MIN_VALUE;
|
max_id = Integer.MIN_VALUE;
|
||||||
@ -77,10 +77,10 @@ public class MediaActivity extends BaseFragment implements NotificationCenter.No
|
|||||||
@Override
|
@Override
|
||||||
public void onFragmentDestroy() {
|
public void onFragmentDestroy() {
|
||||||
super.onFragmentDestroy();
|
super.onFragmentDestroy();
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.mediaDidLoaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.mediaDidLoaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.didReceivedNewMessages);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.didReceivedNewMessages);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.messagesDeleted);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.messagesDeleted);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.messageReceivedByServer);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.messageReceivedByServer);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -152,7 +152,7 @@ public class MediaActivity extends BaseFragment implements NotificationCenter.No
|
|||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, Object... args) {
|
public void didReceivedNotification(int id, Object... args) {
|
||||||
if (id == MessagesController.mediaDidLoaded) {
|
if (id == NotificationCenter.mediaDidLoaded) {
|
||||||
long uid = (Long)args[0];
|
long uid = (Long)args[0];
|
||||||
int guid = (Integer)args[4];
|
int guid = (Integer)args[4];
|
||||||
if (uid == dialog_id && guid == classGuid) {
|
if (uid == dialog_id && guid == classGuid) {
|
||||||
@ -192,7 +192,7 @@ public class MediaActivity extends BaseFragment implements NotificationCenter.No
|
|||||||
listAdapter.notifyDataSetChanged();
|
listAdapter.notifyDataSetChanged();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.messagesDeleted) {
|
} else if (id == NotificationCenter.messagesDeleted) {
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
ArrayList<Integer> markAsDeletedMessages = (ArrayList<Integer>)args[0];
|
ArrayList<Integer> markAsDeletedMessages = (ArrayList<Integer>)args[0];
|
||||||
boolean updated = false;
|
boolean updated = false;
|
||||||
@ -208,7 +208,7 @@ public class MediaActivity extends BaseFragment implements NotificationCenter.No
|
|||||||
if (updated && listAdapter != null) {
|
if (updated && listAdapter != null) {
|
||||||
listAdapter.notifyDataSetChanged();
|
listAdapter.notifyDataSetChanged();
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.didReceivedNewMessages) {
|
} else if (id == NotificationCenter.didReceivedNewMessages) {
|
||||||
long uid = (Long)args[0];
|
long uid = (Long)args[0];
|
||||||
if (uid == dialog_id) {
|
if (uid == dialog_id) {
|
||||||
boolean markAsRead = false;
|
boolean markAsRead = false;
|
||||||
@ -237,7 +237,7 @@ public class MediaActivity extends BaseFragment implements NotificationCenter.No
|
|||||||
listAdapter.notifyDataSetChanged();
|
listAdapter.notifyDataSetChanged();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.messageReceivedByServer) {
|
} else if (id == NotificationCenter.messageReceivedByServer) {
|
||||||
Integer msgId = (Integer)args[0];
|
Integer msgId = (Integer)args[0];
|
||||||
MessageObject obj = messagesDict.get(msgId);
|
MessageObject obj = messagesDict.get(msgId);
|
||||||
if (obj != null) {
|
if (obj != null) {
|
||||||
@ -266,7 +266,7 @@ public class MediaActivity extends BaseFragment implements NotificationCenter.No
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public PhotoViewer.PlaceProviderObject getPlaceForPhoto(MessageObject messageObject, TLRPC.FileLocation fileLocation, int index) {
|
public PhotoViewer.PlaceProviderObject getPlaceForPhoto(MessageObject messageObject, TLRPC.FileLocation fileLocation, int index) {
|
||||||
if (messageObject == null) {
|
if (messageObject == null || listView == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
int count = listView.getChildCount();
|
int count = listView.getChildCount();
|
||||||
|
@ -30,7 +30,7 @@ import org.telegram.android.ContactsController;
|
|||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
import org.telegram.android.MessagesStorage;
|
import org.telegram.android.MessagesStorage;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
@ -87,13 +87,13 @@ public class MessagesActivity extends BaseFragment implements NotificationCenter
|
|||||||
@Override
|
@Override
|
||||||
public boolean onFragmentCreate() {
|
public boolean onFragmentCreate() {
|
||||||
super.onFragmentCreate();
|
super.onFragmentCreate();
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.dialogsNeedReload);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.dialogsNeedReload);
|
||||||
NotificationCenter.getInstance().addObserver(this, 999);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.emojiDidLoaded);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.updateInterfaces);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.reloadSearchResults);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.reloadSearchResults);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.encryptedChatUpdated);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.encryptedChatUpdated);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.contactsDidLoaded);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.contactsDidLoaded);
|
||||||
NotificationCenter.getInstance().addObserver(this, 1234);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.appDidLogout);
|
||||||
if (getArguments() != null) {
|
if (getArguments() != null) {
|
||||||
onlySelect = arguments.getBoolean("onlySelect", false);
|
onlySelect = arguments.getBoolean("onlySelect", false);
|
||||||
serverOnly = arguments.getBoolean("serverOnly", false);
|
serverOnly = arguments.getBoolean("serverOnly", false);
|
||||||
@ -101,7 +101,6 @@ public class MessagesActivity extends BaseFragment implements NotificationCenter
|
|||||||
}
|
}
|
||||||
if (!dialogsLoaded) {
|
if (!dialogsLoaded) {
|
||||||
MessagesController.getInstance().loadDialogs(0, 0, 100, true);
|
MessagesController.getInstance().loadDialogs(0, 0, 100, true);
|
||||||
ContactsController.getInstance().checkAppAccount();
|
|
||||||
dialogsLoaded = true;
|
dialogsLoaded = true;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
@ -110,13 +109,13 @@ public class MessagesActivity extends BaseFragment implements NotificationCenter
|
|||||||
@Override
|
@Override
|
||||||
public void onFragmentDestroy() {
|
public void onFragmentDestroy() {
|
||||||
super.onFragmentDestroy();
|
super.onFragmentDestroy();
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.dialogsNeedReload);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.dialogsNeedReload);
|
||||||
NotificationCenter.getInstance().removeObserver(this, 999);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.emojiDidLoaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.updateInterfaces);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.reloadSearchResults);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.reloadSearchResults);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.encryptedChatUpdated);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.encryptedChatUpdated);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.contactsDidLoaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.contactsDidLoaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, 1234);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.appDidLogout);
|
||||||
delegate = null;
|
delegate = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -350,7 +349,7 @@ public class MessagesActivity extends BaseFragment implements NotificationCenter
|
|||||||
builder.setPositiveButton(LocaleController.getString("OK", R.string.OK), new DialogInterface.OnClickListener() {
|
builder.setPositiveButton(LocaleController.getString("OK", R.string.OK), new DialogInterface.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(DialogInterface dialogInterface, int i) {
|
public void onClick(DialogInterface dialogInterface, int i) {
|
||||||
MessagesController.getInstance().deleteUserFromChat((int) -selectedDialog, MessagesController.getInstance().users.get(UserConfig.getClientUserId()), null);
|
MessagesController.getInstance().deleteUserFromChat((int) -selectedDialog, MessagesController.getInstance().getUser(UserConfig.getClientUserId()), null);
|
||||||
MessagesController.getInstance().deleteDialog(selectedDialog, 0, false);
|
MessagesController.getInstance().deleteDialog(selectedDialog, 0, false);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -428,7 +427,7 @@ public class MessagesActivity extends BaseFragment implements NotificationCenter
|
|||||||
@Override
|
@Override
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
public void didReceivedNotification(int id, Object... args) {
|
public void didReceivedNotification(int id, Object... args) {
|
||||||
if (id == MessagesController.dialogsNeedReload) {
|
if (id == NotificationCenter.dialogsNeedReload) {
|
||||||
if (messagesListViewAdapter != null) {
|
if (messagesListViewAdapter != null) {
|
||||||
messagesListViewAdapter.notifyDataSetChanged();
|
messagesListViewAdapter.notifyDataSetChanged();
|
||||||
}
|
}
|
||||||
@ -453,22 +452,22 @@ public class MessagesActivity extends BaseFragment implements NotificationCenter
|
|||||||
progressView.setVisibility(View.GONE);
|
progressView.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == 999) {
|
} else if (id == NotificationCenter.emojiDidLoaded) {
|
||||||
if (messagesListView != null) {
|
if (messagesListView != null) {
|
||||||
updateVisibleRows(0);
|
updateVisibleRows(0);
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.updateInterfaces) {
|
} else if (id == NotificationCenter.updateInterfaces) {
|
||||||
updateVisibleRows((Integer)args[0]);
|
updateVisibleRows((Integer)args[0]);
|
||||||
} else if (id == MessagesController.reloadSearchResults) {
|
} else if (id == NotificationCenter.reloadSearchResults) {
|
||||||
int token = (Integer)args[0];
|
int token = (Integer)args[0];
|
||||||
if (token == activityToken) {
|
if (token == activityToken) {
|
||||||
updateSearchResults((ArrayList<TLObject>)args[1], (ArrayList<CharSequence>)args[2], (ArrayList<TLRPC.User>)args[3]);
|
updateSearchResults((ArrayList<TLObject>)args[1], (ArrayList<CharSequence>)args[2], (ArrayList<TLRPC.User>)args[3]);
|
||||||
}
|
}
|
||||||
} else if (id == 1234) {
|
} else if (id == NotificationCenter.appDidLogout) {
|
||||||
dialogsLoaded = false;
|
dialogsLoaded = false;
|
||||||
} else if (id == MessagesController.encryptedChatUpdated) {
|
} else if (id == NotificationCenter.encryptedChatUpdated) {
|
||||||
updateVisibleRows(0);
|
updateVisibleRows(0);
|
||||||
} else if (id == MessagesController.contactsDidLoaded) {
|
} else if (id == NotificationCenter.contactsDidLoaded) {
|
||||||
updateVisibleRows(0);
|
updateVisibleRows(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -503,20 +502,20 @@ public class MessagesActivity extends BaseFragment implements NotificationCenter
|
|||||||
int high_id = (int)(dialog_id >> 32);
|
int high_id = (int)(dialog_id >> 32);
|
||||||
if (lower_part != 0) {
|
if (lower_part != 0) {
|
||||||
if (high_id == 1) {
|
if (high_id == 1) {
|
||||||
TLRPC.Chat chat = MessagesController.getInstance().chats.get(lower_part);
|
TLRPC.Chat chat = MessagesController.getInstance().getChat(lower_part);
|
||||||
if (chat == null) {
|
if (chat == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
builder.setMessage(LocaleController.formatStringSimple(selectAlertString, chat.title));
|
builder.setMessage(LocaleController.formatStringSimple(selectAlertString, chat.title));
|
||||||
} else {
|
} else {
|
||||||
if (lower_part > 0) {
|
if (lower_part > 0) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(lower_part);
|
TLRPC.User user = MessagesController.getInstance().getUser(lower_part);
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
builder.setMessage(LocaleController.formatStringSimple(selectAlertString, Utilities.formatName(user.first_name, user.last_name)));
|
builder.setMessage(LocaleController.formatStringSimple(selectAlertString, Utilities.formatName(user.first_name, user.last_name)));
|
||||||
} else if (lower_part < 0) {
|
} else if (lower_part < 0) {
|
||||||
TLRPC.Chat chat = MessagesController.getInstance().chats.get(-lower_part);
|
TLRPC.Chat chat = MessagesController.getInstance().getChat(-lower_part);
|
||||||
if (chat == null) {
|
if (chat == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -524,8 +523,8 @@ public class MessagesActivity extends BaseFragment implements NotificationCenter
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
TLRPC.EncryptedChat chat = MessagesController.getInstance().encryptedChats.get(high_id);
|
TLRPC.EncryptedChat chat = MessagesController.getInstance().getEncryptedChat(high_id);
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(chat.user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(chat.user_id);
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -565,23 +564,23 @@ public class MessagesActivity extends BaseFragment implements NotificationCenter
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void updateSearchResults(final ArrayList<TLObject> result, final ArrayList<CharSequence> names, final ArrayList<TLRPC.User> encUsers) {
|
public void updateSearchResults(final ArrayList<TLObject> result, final ArrayList<CharSequence> names, final ArrayList<TLRPC.User> encUsers) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
for (TLObject obj : result) {
|
for (TLObject obj : result) {
|
||||||
if (obj instanceof TLRPC.User) {
|
if (obj instanceof TLRPC.User) {
|
||||||
TLRPC.User user = (TLRPC.User) obj;
|
TLRPC.User user = (TLRPC.User) obj;
|
||||||
MessagesController.getInstance().users.putIfAbsent(user.id, user);
|
MessagesController.getInstance().putUser(user, true);
|
||||||
} else if (obj instanceof TLRPC.Chat) {
|
} else if (obj instanceof TLRPC.Chat) {
|
||||||
TLRPC.Chat chat = (TLRPC.Chat) obj;
|
TLRPC.Chat chat = (TLRPC.Chat) obj;
|
||||||
MessagesController.getInstance().chats.putIfAbsent(chat.id, chat);
|
MessagesController.getInstance().putChat(chat, true);
|
||||||
} else if (obj instanceof TLRPC.EncryptedChat) {
|
} else if (obj instanceof TLRPC.EncryptedChat) {
|
||||||
TLRPC.EncryptedChat chat = (TLRPC.EncryptedChat) obj;
|
TLRPC.EncryptedChat chat = (TLRPC.EncryptedChat) obj;
|
||||||
MessagesController.getInstance().encryptedChats.putIfAbsent(chat.id, chat);
|
MessagesController.getInstance().putEncryptedChat(chat, true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (TLRPC.User user : encUsers) {
|
for (TLRPC.User user : encUsers) {
|
||||||
MessagesController.getInstance().users.putIfAbsent(user.id, user);
|
MessagesController.getInstance().putUser(user, true);
|
||||||
}
|
}
|
||||||
searchResult = result;
|
searchResult = result;
|
||||||
searchResultNames = names;
|
searchResultNames = names;
|
||||||
@ -687,12 +686,12 @@ public class MessagesActivity extends BaseFragment implements NotificationCenter
|
|||||||
|
|
||||||
TLObject obj = searchResult.get(i);
|
TLObject obj = searchResult.get(i);
|
||||||
if (obj instanceof TLRPC.User) {
|
if (obj instanceof TLRPC.User) {
|
||||||
user = MessagesController.getInstance().users.get(((TLRPC.User)obj).id);
|
user = MessagesController.getInstance().getUser(((TLRPC.User)obj).id);
|
||||||
} else if (obj instanceof TLRPC.Chat) {
|
} else if (obj instanceof TLRPC.Chat) {
|
||||||
chat = MessagesController.getInstance().chats.get(((TLRPC.Chat) obj).id);
|
chat = MessagesController.getInstance().getChat(((TLRPC.Chat) obj).id);
|
||||||
} else if (obj instanceof TLRPC.EncryptedChat) {
|
} else if (obj instanceof TLRPC.EncryptedChat) {
|
||||||
encryptedChat = MessagesController.getInstance().encryptedChats.get(((TLRPC.EncryptedChat) obj).id);
|
encryptedChat = MessagesController.getInstance().getEncryptedChat(((TLRPC.EncryptedChat) obj).id);
|
||||||
user = MessagesController.getInstance().users.get(encryptedChat.user_id);
|
user = MessagesController.getInstance().getUser(encryptedChat.user_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
((ChatOrUserCell)view).setData(user, chat, encryptedChat, searchResultNames.get(i), null);
|
((ChatOrUserCell)view).setData(user, chat, encryptedChat, searchResultNames.get(i), null);
|
||||||
|
@ -28,7 +28,7 @@ import android.widget.FrameLayout;
|
|||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
import org.telegram.android.AndroidUtilities;
|
import org.telegram.android.AndroidUtilities;
|
||||||
import org.telegram.messenger.FileLoader;
|
import org.telegram.android.ImageLoader;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.android.LocaleController;
|
import org.telegram.android.LocaleController;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
@ -310,7 +310,7 @@ public class PhotoCropActivity extends BaseFragment {
|
|||||||
display.getSize(displaySize);
|
display.getSize(displaySize);
|
||||||
}
|
}
|
||||||
int size = Math.max(displaySize.x, displaySize.y);
|
int size = Math.max(displaySize.x, displaySize.y);
|
||||||
imageToCrop = FileLoader.loadBitmap(photoPath, photoUri, size, size);
|
imageToCrop = ImageLoader.loadBitmap(photoPath, photoUri, size, size);
|
||||||
if (imageToCrop == null) {
|
if (imageToCrop == null) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -26,11 +26,10 @@ import android.widget.TextView;
|
|||||||
import org.telegram.android.AndroidUtilities;
|
import org.telegram.android.AndroidUtilities;
|
||||||
import org.telegram.android.LocaleController;
|
import org.telegram.android.LocaleController;
|
||||||
import org.telegram.android.MediaController;
|
import org.telegram.android.MediaController;
|
||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.objects.MessageObject;
|
import org.telegram.android.MessageObject;
|
||||||
import org.telegram.ui.Adapters.BaseFragmentAdapter;
|
import org.telegram.ui.Adapters.BaseFragmentAdapter;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarMenu;
|
import org.telegram.ui.Views.ActionBar.ActionBarMenu;
|
||||||
@ -69,15 +68,15 @@ public class PhotoPickerActivity extends BaseFragment implements NotificationCen
|
|||||||
public boolean onFragmentCreate() {
|
public boolean onFragmentCreate() {
|
||||||
loading = true;
|
loading = true;
|
||||||
MediaController.loadGalleryPhotosAlbums(classGuid);
|
MediaController.loadGalleryPhotosAlbums(classGuid);
|
||||||
NotificationCenter.getInstance().addObserver(this, MediaController.albumsDidLoaded);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.albumsDidLoaded);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.closeChats);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.closeChats);
|
||||||
return super.onFragmentCreate();
|
return super.onFragmentCreate();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onFragmentDestroy() {
|
public void onFragmentDestroy() {
|
||||||
NotificationCenter.getInstance().removeObserver(this, MediaController.albumsDidLoaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.albumsDidLoaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.closeChats);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.closeChats);
|
||||||
super.onFragmentDestroy();
|
super.onFragmentDestroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -199,7 +198,7 @@ public class PhotoPickerActivity extends BaseFragment implements NotificationCen
|
|||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, Object... args) {
|
public void didReceivedNotification(int id, Object... args) {
|
||||||
if (id == MediaController.albumsDidLoaded) {
|
if (id == NotificationCenter.albumsDidLoaded) {
|
||||||
int guid = (Integer)args[0];
|
int guid = (Integer)args[0];
|
||||||
if (classGuid == guid) {
|
if (classGuid == guid) {
|
||||||
albumsSorted = (ArrayList<MediaController.AlbumEntry>)args[1];
|
albumsSorted = (ArrayList<MediaController.AlbumEntry>)args[1];
|
||||||
@ -217,7 +216,7 @@ public class PhotoPickerActivity extends BaseFragment implements NotificationCen
|
|||||||
}
|
}
|
||||||
loading = false;
|
loading = false;
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.closeChats) {
|
} else if (id == NotificationCenter.closeChats) {
|
||||||
removeSelfFromStack();
|
removeSelfFromStack();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -19,6 +19,7 @@ import android.content.Intent;
|
|||||||
import android.graphics.Bitmap;
|
import android.graphics.Bitmap;
|
||||||
import android.graphics.Canvas;
|
import android.graphics.Canvas;
|
||||||
import android.graphics.PixelFormat;
|
import android.graphics.PixelFormat;
|
||||||
|
import android.graphics.Rect;
|
||||||
import android.graphics.drawable.BitmapDrawable;
|
import android.graphics.drawable.BitmapDrawable;
|
||||||
import android.graphics.drawable.ColorDrawable;
|
import android.graphics.drawable.ColorDrawable;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
@ -46,26 +47,27 @@ import android.widget.Scroller;
|
|||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
import org.telegram.android.AndroidUtilities;
|
import org.telegram.android.AndroidUtilities;
|
||||||
|
import org.telegram.android.MessagesStorage;
|
||||||
import org.telegram.messenger.ConnectionsManager;
|
import org.telegram.messenger.ConnectionsManager;
|
||||||
import org.telegram.messenger.FileLoader;
|
import org.telegram.messenger.FileLoader;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.android.LocaleController;
|
import org.telegram.android.LocaleController;
|
||||||
import org.telegram.android.MediaController;
|
import org.telegram.android.MediaController;
|
||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.objects.MessageObject;
|
import org.telegram.android.MessageObject;
|
||||||
import org.telegram.objects.PhotoObject;
|
import org.telegram.android.PhotoObject;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBar;
|
import org.telegram.ui.Views.ActionBar.ActionBar;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarActivity;
|
import org.telegram.ui.Views.ActionBar.ActionBarActivity;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarMenu;
|
import org.telegram.ui.Views.ActionBar.ActionBarMenu;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarMenuItem;
|
import org.telegram.ui.Views.ActionBar.ActionBarMenuItem;
|
||||||
import org.telegram.ui.Views.ClippingImageView;
|
import org.telegram.ui.Views.ClippingImageView;
|
||||||
import org.telegram.ui.Views.ImageReceiver;
|
import org.telegram.android.ImageReceiver;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
@ -91,6 +93,7 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
private FrameLayout bottomLayout;
|
private FrameLayout bottomLayout;
|
||||||
private TextView nameTextView;
|
private TextView nameTextView;
|
||||||
private TextView dateTextView;
|
private TextView dateTextView;
|
||||||
|
private ImageView deleteButton;
|
||||||
private ProgressBar progressBar;
|
private ProgressBar progressBar;
|
||||||
private ActionBarMenuItem menuItem;
|
private ActionBarMenuItem menuItem;
|
||||||
private ColorDrawable backgroundDrawable = new ColorDrawable(0xff000000);
|
private ColorDrawable backgroundDrawable = new ColorDrawable(0xff000000);
|
||||||
@ -171,8 +174,10 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
private ArrayList<MessageObject> imagesArr = new ArrayList<MessageObject>();
|
private ArrayList<MessageObject> imagesArr = new ArrayList<MessageObject>();
|
||||||
private HashMap<Integer, MessageObject> imagesByIds = new HashMap<Integer, MessageObject>();
|
private HashMap<Integer, MessageObject> imagesByIds = new HashMap<Integer, MessageObject>();
|
||||||
private ArrayList<TLRPC.FileLocation> imagesArrLocations = new ArrayList<TLRPC.FileLocation>();
|
private ArrayList<TLRPC.FileLocation> imagesArrLocations = new ArrayList<TLRPC.FileLocation>();
|
||||||
|
private ArrayList<TLRPC.Photo> avatarsArr = new ArrayList<TLRPC.Photo>();
|
||||||
private ArrayList<Integer> imagesArrLocationsSizes = new ArrayList<Integer>();
|
private ArrayList<Integer> imagesArrLocationsSizes = new ArrayList<Integer>();
|
||||||
private ArrayList<MediaController.PhotoEntry> imagesArrLocals = new ArrayList<MediaController.PhotoEntry>();
|
private ArrayList<MediaController.PhotoEntry> imagesArrLocals = new ArrayList<MediaController.PhotoEntry>();
|
||||||
|
private TLRPC.FileLocation currentUserAvatarLocation = null;
|
||||||
|
|
||||||
private final static int gallery_menu_save = 1;
|
private final static int gallery_menu_save = 1;
|
||||||
private final static int gallery_menu_showall = 2;
|
private final static int gallery_menu_showall = 2;
|
||||||
@ -284,19 +289,19 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, Object... args) {
|
public void didReceivedNotification(int id, Object... args) {
|
||||||
if (id == FileLoader.FileDidFailedLoad) {
|
if (id == NotificationCenter.FileDidFailedLoad) {
|
||||||
String location = (String)args[0];
|
String location = (String)args[0];
|
||||||
if (currentFileName != null && currentFileName.equals(location)) {
|
if (currentFileName != null && currentFileName.equals(location)) {
|
||||||
progressBar.setVisibility(View.GONE);
|
progressBar.setVisibility(View.GONE);
|
||||||
updateActionOverlays();
|
updateActionOverlays();
|
||||||
}
|
}
|
||||||
} else if (id == FileLoader.FileDidLoaded) {
|
} else if (id == NotificationCenter.FileDidLoaded) {
|
||||||
String location = (String)args[0];
|
String location = (String)args[0];
|
||||||
if (currentFileName != null && currentFileName.equals(location)) {
|
if (currentFileName != null && currentFileName.equals(location)) {
|
||||||
progressBar.setVisibility(View.GONE);
|
progressBar.setVisibility(View.GONE);
|
||||||
updateActionOverlays();
|
updateActionOverlays();
|
||||||
}
|
}
|
||||||
} else if (id == FileLoader.FileLoadProgressChanged) {
|
} else if (id == NotificationCenter.FileLoadProgressChanged) {
|
||||||
String location = (String)args[0];
|
String location = (String)args[0];
|
||||||
if (currentFileName != null && currentFileName.equals(location)) {
|
if (currentFileName != null && currentFileName.equals(location)) {
|
||||||
Float progress = (Float)args[1];
|
Float progress = (Float)args[1];
|
||||||
@ -313,7 +318,7 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
progressBar.setProgress((int) (progress * 100));
|
progressBar.setProgress((int) (progress * 100));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.userPhotosLoaded) {
|
} else if (id == NotificationCenter.userPhotosLoaded) {
|
||||||
int guid = (Integer)args[4];
|
int guid = (Integer)args[4];
|
||||||
int uid = (Integer)args[0];
|
int uid = (Integer)args[0];
|
||||||
if (avatarsUserId == uid && classGuid == guid) {
|
if (avatarsUserId == uid && classGuid == guid) {
|
||||||
@ -326,6 +331,7 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
}
|
}
|
||||||
imagesArrLocations.clear();
|
imagesArrLocations.clear();
|
||||||
imagesArrLocationsSizes.clear();
|
imagesArrLocationsSizes.clear();
|
||||||
|
avatarsArr.clear();
|
||||||
for (TLRPC.Photo photo : photos) {
|
for (TLRPC.Photo photo : photos) {
|
||||||
if (photo instanceof TLRPC.TL_photoEmpty || photo.sizes == null) {
|
if (photo instanceof TLRPC.TL_photoEmpty || photo.sizes == null) {
|
||||||
continue;
|
continue;
|
||||||
@ -342,13 +348,20 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
}
|
}
|
||||||
imagesArrLocations.add(sizeFull.location);
|
imagesArrLocations.add(sizeFull.location);
|
||||||
imagesArrLocationsSizes.add(sizeFull.size);
|
imagesArrLocationsSizes.add(sizeFull.size);
|
||||||
|
avatarsArr.add(photo);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (!avatarsArr.isEmpty()) {
|
||||||
|
deleteButton.setVisibility(View.VISIBLE);
|
||||||
|
} else {
|
||||||
|
deleteButton.setVisibility(View.GONE);
|
||||||
|
}
|
||||||
needSearchImageInArr = false;
|
needSearchImageInArr = false;
|
||||||
currentIndex = -1;
|
currentIndex = -1;
|
||||||
if (setToImage != -1) {
|
if (setToImage != -1) {
|
||||||
setImageIndex(setToImage, true);
|
setImageIndex(setToImage, true);
|
||||||
} else {
|
} else {
|
||||||
|
avatarsArr.add(0, new TLRPC.TL_photoEmpty());
|
||||||
imagesArrLocations.add(0, currentFileLocation);
|
imagesArrLocations.add(0, currentFileLocation);
|
||||||
imagesArrLocationsSizes.add(0, 0);
|
imagesArrLocationsSizes.add(0, 0);
|
||||||
setImageIndex(0, true);
|
setImageIndex(0, true);
|
||||||
@ -357,7 +370,7 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
MessagesController.getInstance().loadUserPhotos(avatarsUserId, 0, 30, 0, false, classGuid);
|
MessagesController.getInstance().loadUserPhotos(avatarsUserId, 0, 30, 0, false, classGuid);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.mediaCountDidLoaded) {
|
} else if (id == NotificationCenter.mediaCountDidLoaded) {
|
||||||
long uid = (Long)args[0];
|
long uid = (Long)args[0];
|
||||||
if (uid == currentDialogId) {
|
if (uid == currentDialogId) {
|
||||||
if ((int)currentDialogId != 0 && (Boolean)args[2]) {
|
if ((int)currentDialogId != 0 && (Boolean)args[2]) {
|
||||||
@ -372,7 +385,7 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
actionBarLayer.setTitle(LocaleController.formatString("Of", R.string.Of, (totalImagesCount - imagesArr.size()) + currentIndex + 1, totalImagesCount));
|
actionBarLayer.setTitle(LocaleController.formatString("Of", R.string.Of, (totalImagesCount - imagesArr.size()) + currentIndex + 1, totalImagesCount));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.mediaDidLoaded) {
|
} else if (id == NotificationCenter.mediaDidLoaded) {
|
||||||
long uid = (Long)args[0];
|
long uid = (Long)args[0];
|
||||||
int guid = (Integer)args[4];
|
int guid = (Integer)args[4];
|
||||||
if (uid == currentDialogId && guid == classGuid) {
|
if (uid == currentDialogId && guid == classGuid) {
|
||||||
@ -609,7 +622,7 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
ImageView deleteButton = new ImageView(containerView.getContext());
|
deleteButton = new ImageView(containerView.getContext());
|
||||||
deleteButton.setImageResource(R.drawable.ic_ab_delete_white);
|
deleteButton.setImageResource(R.drawable.ic_ab_delete_white);
|
||||||
deleteButton.setScaleType(ImageView.ScaleType.CENTER);
|
deleteButton.setScaleType(ImageView.ScaleType.CENTER);
|
||||||
deleteButton.setBackgroundResource(R.drawable.bar_selector_white);
|
deleteButton.setBackgroundResource(R.drawable.bar_selector_white);
|
||||||
@ -622,16 +635,63 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
deleteButton.setOnClickListener(new View.OnClickListener() {
|
deleteButton.setOnClickListener(new View.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(View v) {
|
public void onClick(View v) {
|
||||||
|
if (!imagesArr.isEmpty()) {
|
||||||
if (currentIndex < 0 || currentIndex >= imagesArr.size()) {
|
if (currentIndex < 0 || currentIndex >= imagesArr.size()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
MessageObject obj = imagesArr.get(currentIndex);
|
MessageObject obj = imagesArr.get(currentIndex);
|
||||||
if (obj.messageOwner.send_state == MessagesController.MESSAGE_SEND_STATE_SENT) {
|
if (obj.messageOwner.send_state == MessageObject.MESSAGE_SEND_STATE_SENT) {
|
||||||
ArrayList<Integer> arr = new ArrayList<Integer>();
|
ArrayList<Integer> arr = new ArrayList<Integer>();
|
||||||
arr.add(obj.messageOwner.id);
|
arr.add(obj.messageOwner.id);
|
||||||
MessagesController.getInstance().deleteMessages(arr, null, null);
|
MessagesController.getInstance().deleteMessages(arr, null, null);
|
||||||
closePhoto(false);
|
closePhoto(false);
|
||||||
}
|
}
|
||||||
|
} else if (!avatarsArr.isEmpty()) {
|
||||||
|
if (currentIndex < 0 || currentIndex >= avatarsArr.size()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
TLRPC.Photo photo = avatarsArr.get(currentIndex);
|
||||||
|
TLRPC.FileLocation currentLocation = imagesArrLocations.get(currentIndex);
|
||||||
|
if (photo instanceof TLRPC.TL_photoEmpty) {
|
||||||
|
photo = null;
|
||||||
|
}
|
||||||
|
boolean current = false;
|
||||||
|
if (currentUserAvatarLocation != null) {
|
||||||
|
if (photo != null) {
|
||||||
|
for (TLRPC.PhotoSize size : photo.sizes) {
|
||||||
|
if (size.location.local_id == currentUserAvatarLocation.local_id && size.location.volume_id == currentUserAvatarLocation.volume_id) {
|
||||||
|
current = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (currentLocation.local_id == currentUserAvatarLocation.local_id && currentLocation.volume_id == currentUserAvatarLocation.volume_id) {
|
||||||
|
current = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (current) {
|
||||||
|
MessagesController.getInstance().deleteUserPhoto(null);
|
||||||
|
closePhoto(false);
|
||||||
|
} else {
|
||||||
|
TLRPC.TL_inputPhoto inputPhoto = new TLRPC.TL_inputPhoto();
|
||||||
|
inputPhoto.id = photo.id;
|
||||||
|
inputPhoto.access_hash = photo.access_hash;
|
||||||
|
MessagesController.getInstance().deleteUserPhoto(inputPhoto);
|
||||||
|
MessagesStorage.getInstance().clearUserPhoto(avatarsUserId, photo.id);
|
||||||
|
imagesArrLocations.remove(currentIndex);
|
||||||
|
imagesArrLocationsSizes.remove(currentIndex);
|
||||||
|
avatarsArr.remove(currentIndex);
|
||||||
|
if (imagesArrLocations.isEmpty()) {
|
||||||
|
closePhoto(false);
|
||||||
|
} else {
|
||||||
|
int index = currentIndex;
|
||||||
|
if (index >= avatarsArr.size()) {
|
||||||
|
index = avatarsArr.size() - 1;
|
||||||
|
}
|
||||||
|
currentIndex = -1;
|
||||||
|
setImageIndex(index, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -720,9 +780,9 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
gestureDetector = new GestureDetector(containerView.getContext(), this);
|
gestureDetector = new GestureDetector(containerView.getContext(), this);
|
||||||
gestureDetector.setOnDoubleTapListener(this);
|
gestureDetector.setOnDoubleTapListener(this);
|
||||||
|
|
||||||
centerImage.parentView = containerView;
|
centerImage.setParentView(containerView);
|
||||||
leftImage.parentView = containerView;
|
leftImage.setParentView(containerView);
|
||||||
rightImage.parentView = containerView;
|
rightImage.setParentView(containerView);
|
||||||
|
|
||||||
currentOverlay = new OverlayView(containerView.getContext());
|
currentOverlay = new OverlayView(containerView.getContext());
|
||||||
containerView.addView(currentOverlay);
|
containerView.addView(currentOverlay);
|
||||||
@ -996,7 +1056,7 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (currentFileName.endsWith("mp4")) {
|
if (currentFileName.endsWith("mp4")) {
|
||||||
if (currentMessageObject.messageOwner.send_state != MessagesController.MESSAGE_SEND_STATE_SENDING && currentMessageObject.messageOwner.send_state != MessagesController.MESSAGE_SEND_STATE_SEND_ERROR) {
|
if (currentMessageObject.messageOwner.send_state != MessageObject.MESSAGE_SEND_STATE_SENDING && currentMessageObject.messageOwner.send_state != MessageObject.MESSAGE_SEND_STATE_SEND_ERROR) {
|
||||||
currentOverlay.setVisibility(View.VISIBLE);
|
currentOverlay.setVisibility(View.VISIBLE);
|
||||||
boolean load = false;
|
boolean load = false;
|
||||||
if (currentMessageObject.messageOwner.attachPath != null && currentMessageObject.messageOwner.attachPath.length() != 0) {
|
if (currentMessageObject.messageOwner.attachPath != null && currentMessageObject.messageOwner.attachPath.length() != 0) {
|
||||||
@ -1016,7 +1076,7 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
}
|
}
|
||||||
if (load) {
|
if (load) {
|
||||||
if (FileLoader.getInstance().isLoadingFile(currentFileName)) {
|
if (FileLoader.getInstance().isLoadingFile(currentFileName)) {
|
||||||
Float progress = FileLoader.getInstance().fileProgresses.get(currentFileName);
|
Float progress = FileLoader.getInstance().getFileProgress(currentFileName);
|
||||||
currentOverlay.actionButton.setText(LocaleController.getString("CancelDownload", R.string.CancelDownload));
|
currentOverlay.actionButton.setText(LocaleController.getString("CancelDownload", R.string.CancelDownload));
|
||||||
progressBar.setVisibility(View.VISIBLE);
|
progressBar.setVisibility(View.VISIBLE);
|
||||||
if (progress != null) {
|
if (progress != null) {
|
||||||
@ -1052,10 +1112,12 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
imagesArr.clear();
|
imagesArr.clear();
|
||||||
imagesArrLocations.clear();
|
imagesArrLocations.clear();
|
||||||
imagesArrLocationsSizes.clear();
|
imagesArrLocationsSizes.clear();
|
||||||
|
avatarsArr.clear();
|
||||||
imagesArrLocals.clear();
|
imagesArrLocals.clear();
|
||||||
imagesByIds.clear();
|
imagesByIds.clear();
|
||||||
imagesArrTemp.clear();
|
imagesArrTemp.clear();
|
||||||
imagesByIdsTemp.clear();
|
imagesByIdsTemp.clear();
|
||||||
|
currentUserAvatarLocation = null;
|
||||||
currentThumb = object.thumb;
|
currentThumb = object.thumb;
|
||||||
menuItem.setVisibility(View.VISIBLE);
|
menuItem.setVisibility(View.VISIBLE);
|
||||||
bottomLayout.setVisibility(View.VISIBLE);
|
bottomLayout.setVisibility(View.VISIBLE);
|
||||||
@ -1089,10 +1151,11 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
avatarsUserId = object.user_id;
|
avatarsUserId = object.user_id;
|
||||||
imagesArrLocations.add(fileLocation);
|
imagesArrLocations.add(fileLocation);
|
||||||
imagesArrLocationsSizes.add(object.size);
|
imagesArrLocationsSizes.add(object.size);
|
||||||
|
avatarsArr.add(new TLRPC.TL_photoEmpty());
|
||||||
bottomLayout.setVisibility(View.GONE);
|
bottomLayout.setVisibility(View.GONE);
|
||||||
canShowBottom = false;
|
|
||||||
menuItem.hideSubItem(gallery_menu_showall);
|
menuItem.hideSubItem(gallery_menu_showall);
|
||||||
setImageIndex(0, true);
|
setImageIndex(0, true);
|
||||||
|
currentUserAvatarLocation = fileLocation;
|
||||||
} else if (messages != null) {
|
} else if (messages != null) {
|
||||||
imagesArr.addAll(messages);
|
imagesArr.addAll(messages);
|
||||||
Collections.reverse(imagesArr);
|
Collections.reverse(imagesArr);
|
||||||
@ -1151,8 +1214,9 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
currentFileName = getFileName(index, null);
|
currentFileName = getFileName(index, null);
|
||||||
|
|
||||||
if (!imagesArr.isEmpty()) {
|
if (!imagesArr.isEmpty()) {
|
||||||
|
deleteButton.setVisibility(View.VISIBLE);
|
||||||
currentMessageObject = imagesArr.get(currentIndex);
|
currentMessageObject = imagesArr.get(currentIndex);
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(currentMessageObject.messageOwner.from_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(currentMessageObject.messageOwner.from_id);
|
||||||
if (user != null) {
|
if (user != null) {
|
||||||
nameTextView.setText(Utilities.formatName(user.first_name, user.last_name));
|
nameTextView.setText(Utilities.formatName(user.first_name, user.last_name));
|
||||||
} else {
|
} else {
|
||||||
@ -1169,6 +1233,13 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
actionBarLayer.setTitle(LocaleController.formatString("Of", R.string.Of, (totalImagesCount - imagesArr.size()) + currentIndex + 1, totalImagesCount));
|
actionBarLayer.setTitle(LocaleController.formatString("Of", R.string.Of, (totalImagesCount - imagesArr.size()) + currentIndex + 1, totalImagesCount));
|
||||||
}
|
}
|
||||||
} else if (!imagesArrLocations.isEmpty()) {
|
} else if (!imagesArrLocations.isEmpty()) {
|
||||||
|
nameTextView.setText("");
|
||||||
|
dateTextView.setText("");
|
||||||
|
if (avatarsUserId == UserConfig.getClientUserId() && !avatarsArr.isEmpty()) {
|
||||||
|
deleteButton.setVisibility(View.VISIBLE);
|
||||||
|
} else {
|
||||||
|
deleteButton.setVisibility(View.GONE);
|
||||||
|
}
|
||||||
currentFileLocation = imagesArrLocations.get(index);
|
currentFileLocation = imagesArrLocations.get(index);
|
||||||
actionBarLayer.setTitle(LocaleController.formatString("Of", R.string.Of, currentIndex + 1, imagesArrLocations.size()));
|
actionBarLayer.setTitle(LocaleController.formatString("Of", R.string.Of, currentIndex + 1, imagesArrLocations.size()));
|
||||||
} else if (!imagesArrLocals.isEmpty()) {
|
} else if (!imagesArrLocals.isEmpty()) {
|
||||||
@ -1261,7 +1332,7 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
} else {
|
} else {
|
||||||
progressBar.setVisibility(View.VISIBLE);
|
progressBar.setVisibility(View.VISIBLE);
|
||||||
}
|
}
|
||||||
Float progress = FileLoader.getInstance().fileProgresses.get(currentFileName);
|
Float progress = FileLoader.getInstance().getFileProgress(currentFileName);
|
||||||
if (progress != null) {
|
if (progress != null) {
|
||||||
progressBar.setProgress((int)(progress * 100));
|
progressBar.setProgress((int)(progress * 100));
|
||||||
} else {
|
} else {
|
||||||
@ -1380,12 +1451,12 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
}
|
}
|
||||||
|
|
||||||
actionBarLayer.setTitle(LocaleController.formatString("Of", R.string.Of, 1, 1));
|
actionBarLayer.setTitle(LocaleController.formatString("Of", R.string.Of, 1, 1));
|
||||||
NotificationCenter.getInstance().addObserver(this, FileLoader.FileDidFailedLoad);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.FileDidFailedLoad);
|
||||||
NotificationCenter.getInstance().addObserver(this, FileLoader.FileDidLoaded);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.FileDidLoaded);
|
||||||
NotificationCenter.getInstance().addObserver(this, FileLoader.FileLoadProgressChanged);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.FileLoadProgressChanged);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.mediaCountDidLoaded);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.mediaCountDidLoaded);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.mediaDidLoaded);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.mediaDidLoaded);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.userPhotosLoaded);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.userPhotosLoaded);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
if (windowView.getParent() != null) {
|
if (windowView.getParent() != null) {
|
||||||
@ -1415,6 +1486,8 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
if(android.os.Build.VERSION.SDK_INT >= 11) {
|
if(android.os.Build.VERSION.SDK_INT >= 11) {
|
||||||
AndroidUtilities.lockOrientation(parentActivity);
|
AndroidUtilities.lockOrientation(parentActivity);
|
||||||
|
|
||||||
|
final Rect drawRegion = object.imageReceiver.getDrawRegion();
|
||||||
|
|
||||||
animatingImageView.setVisibility(View.VISIBLE);
|
animatingImageView.setVisibility(View.VISIBLE);
|
||||||
animatingImageView.setImageBitmap(object.thumb);
|
animatingImageView.setImageBitmap(object.thumb);
|
||||||
|
|
||||||
@ -1423,11 +1496,11 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
animatingImageView.setPivotY(0);
|
animatingImageView.setPivotY(0);
|
||||||
animatingImageView.setScaleX(1);
|
animatingImageView.setScaleX(1);
|
||||||
animatingImageView.setScaleY(1);
|
animatingImageView.setScaleY(1);
|
||||||
animatingImageView.setTranslationX(object.viewX + object.imageReceiver.drawRegion.left);
|
animatingImageView.setTranslationX(object.viewX + drawRegion.left);
|
||||||
animatingImageView.setTranslationY(object.viewY + object.imageReceiver.drawRegion.top);
|
animatingImageView.setTranslationY(object.viewY + drawRegion.top);
|
||||||
final ViewGroup.LayoutParams layoutParams = animatingImageView.getLayoutParams();
|
final ViewGroup.LayoutParams layoutParams = animatingImageView.getLayoutParams();
|
||||||
layoutParams.width = object.imageReceiver.drawRegion.right - object.imageReceiver.drawRegion.left;
|
layoutParams.width = drawRegion.right - drawRegion.left;
|
||||||
layoutParams.height = object.imageReceiver.drawRegion.bottom - object.imageReceiver.drawRegion.top;
|
layoutParams.height = drawRegion.bottom - drawRegion.top;
|
||||||
animatingImageView.setLayoutParams(layoutParams);
|
animatingImageView.setLayoutParams(layoutParams);
|
||||||
|
|
||||||
containerView.getViewTreeObserver().addOnPreDrawListener(new ViewTreeObserver.OnPreDrawListener() {
|
containerView.getViewTreeObserver().addOnPreDrawListener(new ViewTreeObserver.OnPreDrawListener() {
|
||||||
@ -1442,16 +1515,16 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
float height = layoutParams.height * scale;
|
float height = layoutParams.height * scale;
|
||||||
float xPos = (AndroidUtilities.displaySize.x - width) / 2.0f;
|
float xPos = (AndroidUtilities.displaySize.x - width) / 2.0f;
|
||||||
float yPos = (AndroidUtilities.displaySize.y - AndroidUtilities.statusBarHeight - height) / 2.0f;
|
float yPos = (AndroidUtilities.displaySize.y - AndroidUtilities.statusBarHeight - height) / 2.0f;
|
||||||
int clipHorizontal = Math.abs(object.imageReceiver.drawRegion.left - object.imageReceiver.imageX);
|
int clipHorizontal = Math.abs(drawRegion.left - object.imageReceiver.getImageX());
|
||||||
int clipVertical = Math.abs(object.imageReceiver.drawRegion.top - object.imageReceiver.imageY);
|
int clipVertical = Math.abs(drawRegion.top - object.imageReceiver.getImageY());
|
||||||
|
|
||||||
int coords2[] = new int[2];
|
int coords2[] = new int[2];
|
||||||
object.parentView.getLocationInWindow(coords2);
|
object.parentView.getLocationInWindow(coords2);
|
||||||
int clipTop = coords2[1] - AndroidUtilities.statusBarHeight - (object.viewY + object.imageReceiver.drawRegion.top);
|
int clipTop = coords2[1] - AndroidUtilities.statusBarHeight - (object.viewY + drawRegion.top);
|
||||||
if (clipTop < 0) {
|
if (clipTop < 0) {
|
||||||
clipTop = 0;
|
clipTop = 0;
|
||||||
}
|
}
|
||||||
int clipBottom = (object.viewY + object.imageReceiver.drawRegion.top + layoutParams.height) - (coords2[1] + object.parentView.getHeight() - AndroidUtilities.statusBarHeight);
|
int clipBottom = (object.viewY + drawRegion.top + layoutParams.height) - (coords2[1] + object.parentView.getHeight() - AndroidUtilities.statusBarHeight);
|
||||||
if (clipBottom < 0) {
|
if (clipBottom < 0) {
|
||||||
clipBottom = 0;
|
clipBottom = 0;
|
||||||
}
|
}
|
||||||
@ -1544,12 +1617,12 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
NotificationCenter.getInstance().removeObserver(this, FileLoader.FileDidFailedLoad);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.FileDidFailedLoad);
|
||||||
NotificationCenter.getInstance().removeObserver(this, FileLoader.FileDidLoaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.FileDidLoaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, FileLoader.FileLoadProgressChanged);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.FileLoadProgressChanged);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.mediaCountDidLoaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.mediaCountDidLoaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.mediaDidLoaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.mediaDidLoaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.userPhotosLoaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.userPhotosLoaded);
|
||||||
ConnectionsManager.getInstance().cancelRpcsForClassGuid(classGuid);
|
ConnectionsManager.getInstance().cancelRpcsForClassGuid(classGuid);
|
||||||
|
|
||||||
isVisible = false;
|
isVisible = false;
|
||||||
@ -1573,13 +1646,15 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
AnimatorSet animatorSet = new AnimatorSet();
|
AnimatorSet animatorSet = new AnimatorSet();
|
||||||
|
|
||||||
final ViewGroup.LayoutParams layoutParams = animatingImageView.getLayoutParams();
|
final ViewGroup.LayoutParams layoutParams = animatingImageView.getLayoutParams();
|
||||||
|
Rect drawRegion = null;
|
||||||
if (object != null) {
|
if (object != null) {
|
||||||
layoutParams.width = object.imageReceiver.drawRegion.right - object.imageReceiver.drawRegion.left;
|
drawRegion = object.imageReceiver.getDrawRegion();
|
||||||
layoutParams.height = object.imageReceiver.drawRegion.bottom - object.imageReceiver.drawRegion.top;
|
layoutParams.width = drawRegion.right - drawRegion.left;
|
||||||
|
layoutParams.height = drawRegion.bottom - drawRegion.top;
|
||||||
animatingImageView.setImageBitmap(object.thumb);
|
animatingImageView.setImageBitmap(object.thumb);
|
||||||
} else {
|
} else {
|
||||||
layoutParams.width = centerImage.imageW;
|
layoutParams.width = centerImage.getImageWidth();
|
||||||
layoutParams.height = centerImage.imageH;
|
layoutParams.height = centerImage.getImageHeight();
|
||||||
animatingImageView.setImageBitmap(centerImage.getBitmap());
|
animatingImageView.setImageBitmap(centerImage.getBitmap());
|
||||||
}
|
}
|
||||||
animatingImageView.setLayoutParams(layoutParams);
|
animatingImageView.setLayoutParams(layoutParams);
|
||||||
@ -1600,16 +1675,16 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
if (android.os.Build.VERSION.SDK_INT >= 11) {
|
if (android.os.Build.VERSION.SDK_INT >= 11) {
|
||||||
object.imageReceiver.setVisible(false, true);
|
object.imageReceiver.setVisible(false, true);
|
||||||
}
|
}
|
||||||
int clipHorizontal = Math.abs(object.imageReceiver.drawRegion.left - object.imageReceiver.imageX);
|
int clipHorizontal = Math.abs(drawRegion.left - object.imageReceiver.getImageX());
|
||||||
int clipVertical = Math.abs(object.imageReceiver.drawRegion.top - object.imageReceiver.imageY);
|
int clipVertical = Math.abs(drawRegion.top - object.imageReceiver.getImageY());
|
||||||
|
|
||||||
int coords2[] = new int[2];
|
int coords2[] = new int[2];
|
||||||
object.parentView.getLocationInWindow(coords2);
|
object.parentView.getLocationInWindow(coords2);
|
||||||
int clipTop = coords2[1] - AndroidUtilities.statusBarHeight - (object.viewY + object.imageReceiver.drawRegion.top);
|
int clipTop = coords2[1] - AndroidUtilities.statusBarHeight - (object.viewY + drawRegion.top);
|
||||||
if (clipTop < 0) {
|
if (clipTop < 0) {
|
||||||
clipTop = 0;
|
clipTop = 0;
|
||||||
}
|
}
|
||||||
int clipBottom = (object.viewY + object.imageReceiver.drawRegion.top + (object.imageReceiver.drawRegion.bottom - object.imageReceiver.drawRegion.top)) - (coords2[1] + object.parentView.getHeight() - AndroidUtilities.statusBarHeight);
|
int clipBottom = (object.viewY + drawRegion.top + (drawRegion.bottom - drawRegion.top)) - (coords2[1] + object.parentView.getHeight() - AndroidUtilities.statusBarHeight);
|
||||||
if (clipBottom < 0) {
|
if (clipBottom < 0) {
|
||||||
clipBottom = 0;
|
clipBottom = 0;
|
||||||
}
|
}
|
||||||
@ -1620,8 +1695,8 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
animatorSet.playTogether(
|
animatorSet.playTogether(
|
||||||
ObjectAnimator.ofFloat(animatingImageView, "scaleX", 1),
|
ObjectAnimator.ofFloat(animatingImageView, "scaleX", 1),
|
||||||
ObjectAnimator.ofFloat(animatingImageView, "scaleY", 1),
|
ObjectAnimator.ofFloat(animatingImageView, "scaleY", 1),
|
||||||
ObjectAnimator.ofFloat(animatingImageView, "translationX", object.viewX + object.imageReceiver.drawRegion.left),
|
ObjectAnimator.ofFloat(animatingImageView, "translationX", object.viewX + drawRegion.left),
|
||||||
ObjectAnimator.ofFloat(animatingImageView, "translationY", object.viewY + object.imageReceiver.drawRegion.top),
|
ObjectAnimator.ofFloat(animatingImageView, "translationY", object.viewY + drawRegion.top),
|
||||||
ObjectAnimator.ofInt(backgroundDrawable, "alpha", 0),
|
ObjectAnimator.ofInt(backgroundDrawable, "alpha", 0),
|
||||||
ObjectAnimator.ofInt(animatingImageView, "clipHorizontal", clipHorizontal),
|
ObjectAnimator.ofInt(animatingImageView, "clipHorizontal", clipHorizontal),
|
||||||
ObjectAnimator.ofInt(animatingImageView, "clipTop", clipTop),
|
ObjectAnimator.ofInt(animatingImageView, "clipTop", clipTop),
|
||||||
@ -1763,8 +1838,8 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void updateMinMax(float scale) {
|
private void updateMinMax(float scale) {
|
||||||
int maxW = (int) (centerImage.imageW * scale - containerView.getWidth()) / 2;
|
int maxW = (int) (centerImage.getImageWidth() * scale - containerView.getWidth()) / 2;
|
||||||
int maxH = (int) (centerImage.imageH * scale - containerView.getHeight()) / 2;
|
int maxH = (int) (centerImage.getImageHeight() * scale - containerView.getHeight()) / 2;
|
||||||
if (maxW > 0) {
|
if (maxW > 0) {
|
||||||
minX = -maxW;
|
minX = -maxW;
|
||||||
maxX = maxW;
|
maxX = maxW;
|
||||||
@ -1985,7 +2060,7 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
private void goToNext() {
|
private void goToNext() {
|
||||||
float extra = 0;
|
float extra = 0;
|
||||||
if (scale != 1) {
|
if (scale != 1) {
|
||||||
extra = (containerView.getWidth() - centerImage.imageW) / 2 * scale;
|
extra = (containerView.getWidth() - centerImage.getImageWidth()) / 2 * scale;
|
||||||
}
|
}
|
||||||
switchImageAfterAnimation = 1;
|
switchImageAfterAnimation = 1;
|
||||||
animateTo(scale, minX - containerView.getWidth() - extra - PAGE_SPACING / 2, translationY);
|
animateTo(scale, minX - containerView.getWidth() - extra - PAGE_SPACING / 2, translationY);
|
||||||
@ -1994,7 +2069,7 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
private void goToPrev() {
|
private void goToPrev() {
|
||||||
float extra = 0;
|
float extra = 0;
|
||||||
if (scale != 1) {
|
if (scale != 1) {
|
||||||
extra = (containerView.getWidth() - centerImage.imageW) / 2 * scale;
|
extra = (containerView.getWidth() - centerImage.getImageWidth()) / 2 * scale;
|
||||||
}
|
}
|
||||||
switchImageAfterAnimation = 2;
|
switchImageAfterAnimation = 2;
|
||||||
animateTo(scale, maxX + containerView.getWidth() + extra + PAGE_SPACING / 2, translationY);
|
animateTo(scale, maxX + containerView.getWidth() + extra + PAGE_SPACING / 2, translationY);
|
||||||
@ -2117,11 +2192,8 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
int width = (int) (bitmapWidth * scale);
|
int width = (int) (bitmapWidth * scale);
|
||||||
int height = (int) (bitmapHeight * scale);
|
int height = (int) (bitmapHeight * scale);
|
||||||
|
|
||||||
centerImage.imageX = -width / 2;
|
centerImage.setImageCoords(-width / 2, -height / 2, width, height);
|
||||||
centerImage.imageY = -height / 2;
|
centerImage.draw(canvas, -width / 2, -height / 2, width, height);
|
||||||
centerImage.imageW = width;
|
|
||||||
centerImage.imageH = height;
|
|
||||||
centerImage.draw(canvas, centerImage.imageX, centerImage.imageY, centerImage.imageW, centerImage.imageH);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (scale >= 1.0f) {
|
if (scale >= 1.0f) {
|
||||||
@ -2151,11 +2223,8 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
int width = (int) (bitmapWidth * scale);
|
int width = (int) (bitmapWidth * scale);
|
||||||
int height = (int) (bitmapHeight * scale);
|
int height = (int) (bitmapHeight * scale);
|
||||||
|
|
||||||
sideImage.imageX = -width / 2;
|
sideImage.setImageCoords(-width / 2, -height / 2, width, height);
|
||||||
sideImage.imageY = -height / 2;
|
sideImage.draw(canvas, -width / 2, -height / 2, width, height);
|
||||||
sideImage.imageW = width;
|
|
||||||
sideImage.imageH = height;
|
|
||||||
sideImage.draw(canvas, sideImage.imageX, sideImage.imageY, sideImage.imageW, sideImage.imageH);
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
changingPage = false;
|
changingPage = false;
|
||||||
@ -2220,9 +2289,9 @@ public class PhotoViewer implements NotificationCenter.NotificationCenterDelegat
|
|||||||
}
|
}
|
||||||
if (loadFile) {
|
if (loadFile) {
|
||||||
if (!FileLoader.getInstance().isLoadingFile(currentFileName)) {
|
if (!FileLoader.getInstance().isLoadingFile(currentFileName)) {
|
||||||
FileLoader.getInstance().loadFile(currentMessageObject.messageOwner.media.video, null, null, null);
|
FileLoader.getInstance().loadFile(currentMessageObject.messageOwner.media.video);
|
||||||
} else {
|
} else {
|
||||||
FileLoader.getInstance().cancelLoadFile(currentMessageObject.messageOwner.media.video, null, null, null);
|
FileLoader.getInstance().cancelLoadFile(currentMessageObject.messageOwner.media.video);
|
||||||
}
|
}
|
||||||
updateActionOverlays();
|
updateActionOverlays();
|
||||||
}
|
}
|
||||||
|
@ -12,7 +12,6 @@ import android.app.Activity;
|
|||||||
import android.app.KeyguardManager;
|
import android.app.KeyguardManager;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.SharedPreferences;
|
|
||||||
import android.content.res.Configuration;
|
import android.content.res.Configuration;
|
||||||
import android.graphics.drawable.AnimationDrawable;
|
import android.graphics.drawable.AnimationDrawable;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
@ -39,13 +38,14 @@ import org.telegram.android.MessagesController;
|
|||||||
import org.telegram.PhoneFormat.PhoneFormat;
|
import org.telegram.PhoneFormat.PhoneFormat;
|
||||||
import org.telegram.android.NotificationsController;
|
import org.telegram.android.NotificationsController;
|
||||||
import org.telegram.messenger.ConnectionsManager;
|
import org.telegram.messenger.ConnectionsManager;
|
||||||
|
import org.telegram.messenger.FileLoader;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.objects.MessageObject;
|
import org.telegram.android.MessageObject;
|
||||||
import org.telegram.objects.PhotoObject;
|
import org.telegram.android.PhotoObject;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBar;
|
import org.telegram.ui.Views.ActionBar.ActionBar;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarMenu;
|
import org.telegram.ui.Views.ActionBar.ActionBarMenu;
|
||||||
@ -80,8 +80,6 @@ public class PopupNotificationActivity extends Activity implements NotificationC
|
|||||||
private MessageObject currentMessageObject = null;
|
private MessageObject currentMessageObject = null;
|
||||||
private int currentMessageNum = 0;
|
private int currentMessageNum = 0;
|
||||||
private PowerManager.WakeLock wakeLock = null;
|
private PowerManager.WakeLock wakeLock = null;
|
||||||
private int downloadAudios = 0;
|
|
||||||
private int downloadPhotos = 0;
|
|
||||||
private boolean animationInProgress = false;
|
private boolean animationInProgress = false;
|
||||||
private long animationStartTime = 0;
|
private long animationStartTime = 0;
|
||||||
private float moveStartX = -1;
|
private float moveStartX = -1;
|
||||||
@ -145,13 +143,13 @@ public class PopupNotificationActivity extends Activity implements NotificationC
|
|||||||
protected void onCreate(Bundle savedInstanceState) {
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
classGuid = ConnectionsManager.getInstance().generateClassGuid();
|
classGuid = ConnectionsManager.getInstance().generateClassGuid();
|
||||||
NotificationCenter.getInstance().addObserver(this, 1234);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.appDidLogout);
|
||||||
NotificationCenter.getInstance().addObserver(this, NotificationsController.pushMessagesUpdated);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.pushMessagesUpdated);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.updateInterfaces);
|
||||||
NotificationCenter.getInstance().addObserver(this, MediaController.audioProgressDidChanged);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.audioProgressDidChanged);
|
||||||
NotificationCenter.getInstance().addObserver(this, MediaController.audioDidReset);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.audioDidReset);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.contactsDidLoaded);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.contactsDidLoaded);
|
||||||
NotificationCenter.getInstance().addObserver(this, 999);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.emojiDidLoaded);
|
||||||
|
|
||||||
chatActivityEnterView = new ChatActivityEnterView();
|
chatActivityEnterView = new ChatActivityEnterView();
|
||||||
chatActivityEnterView.setDelegate(new ChatActivityEnterView.ChatActivityEnterViewDelegate() {
|
chatActivityEnterView.setDelegate(new ChatActivityEnterView.ChatActivityEnterViewDelegate() {
|
||||||
@ -442,19 +440,19 @@ public class PopupNotificationActivity extends Activity implements NotificationC
|
|||||||
|
|
||||||
TextView messageText = (TextView)view.findViewById(R.id.message_text);
|
TextView messageText = (TextView)view.findViewById(R.id.message_text);
|
||||||
BackupImageView imageView = (BackupImageView) view.findViewById(R.id.message_image);
|
BackupImageView imageView = (BackupImageView) view.findViewById(R.id.message_image);
|
||||||
imageView.imageReceiver.isAspectFit = true;
|
imageView.imageReceiver.setAspectFit(true);
|
||||||
PhotoObject currentPhotoObject = PhotoObject.getClosestImageWithSize(messageObject.photoThumbs, 800, 800);
|
PhotoObject currentPhotoObject = PhotoObject.getClosestImageWithSize(messageObject.photoThumbs, 800, 800);
|
||||||
boolean photoSet = false;
|
boolean photoSet = false;
|
||||||
if (currentPhotoObject != null) {
|
if (currentPhotoObject != null) {
|
||||||
boolean photoExist = true;
|
boolean photoExist = true;
|
||||||
String fileName = MessageObject.getAttachFileName(currentPhotoObject.photoOwner);
|
String fileName = FileLoader.getAttachFileName(currentPhotoObject.photoOwner);
|
||||||
if (messageObject.type == 1) {
|
if (messageObject.type == 1) {
|
||||||
File cacheFile = new File(AndroidUtilities.getCacheDir(), fileName);
|
File cacheFile = new File(AndroidUtilities.getCacheDir(), fileName);
|
||||||
if (!cacheFile.exists()) {
|
if (!cacheFile.exists()) {
|
||||||
photoExist = false;
|
photoExist = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (photoExist || downloadPhotos == 0 || downloadPhotos == 2 && ConnectionsManager.isConnectedToWiFi()) {
|
if (photoExist || MediaController.getInstance().canDownloadMedia(MediaController.AUTODOWNLOAD_MASK_PHOTO)) {
|
||||||
imageView.setImage(currentPhotoObject.photoOwner.location, "100_100", messageObject.imagePreview, currentPhotoObject.photoOwner.size);
|
imageView.setImage(currentPhotoObject.photoOwner.location, "100_100", messageObject.imagePreview, currentPhotoObject.photoOwner.size);
|
||||||
photoSet = true;
|
photoSet = true;
|
||||||
} else {
|
} else {
|
||||||
@ -498,7 +496,7 @@ public class PopupNotificationActivity extends Activity implements NotificationC
|
|||||||
}
|
}
|
||||||
|
|
||||||
cell.setMessageObject(messageObject);
|
cell.setMessageObject(messageObject);
|
||||||
if ((downloadAudios == 0 || downloadAudios == 2 && ConnectionsManager.isConnectedToWiFi())) {
|
if (MediaController.getInstance().canDownloadMedia(MediaController.AUTODOWNLOAD_MASK_AUDIO)) {
|
||||||
cell.downloadAudioIfNeed();
|
cell.downloadAudioIfNeed();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -727,14 +725,14 @@ public class PopupNotificationActivity extends Activity implements NotificationC
|
|||||||
if ((int)dialog_id != 0) {
|
if ((int)dialog_id != 0) {
|
||||||
int lower_id = (int)dialog_id;
|
int lower_id = (int)dialog_id;
|
||||||
if (lower_id > 0) {
|
if (lower_id > 0) {
|
||||||
currentUser = MessagesController.getInstance().users.get(lower_id);
|
currentUser = MessagesController.getInstance().getUser(lower_id);
|
||||||
} else {
|
} else {
|
||||||
currentChat = MessagesController.getInstance().chats.get(-lower_id);
|
currentChat = MessagesController.getInstance().getChat(-lower_id);
|
||||||
currentUser = MessagesController.getInstance().users.get(currentMessageObject.messageOwner.from_id);
|
currentUser = MessagesController.getInstance().getUser(currentMessageObject.messageOwner.from_id);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
TLRPC.EncryptedChat encryptedChat = MessagesController.getInstance().encryptedChats.get((int)(dialog_id >> 32));
|
TLRPC.EncryptedChat encryptedChat = MessagesController.getInstance().getEncryptedChat((int)(dialog_id >> 32));
|
||||||
currentUser = MessagesController.getInstance().users.get(encryptedChat.user_id);
|
currentUser = MessagesController.getInstance().getUser(encryptedChat.user_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (currentChat != null && currentUser != null) {
|
if (currentChat != null && currentUser != null) {
|
||||||
@ -750,16 +748,6 @@ public class PopupNotificationActivity extends Activity implements NotificationC
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("mainconfig", Activity.MODE_PRIVATE);
|
|
||||||
|
|
||||||
if (currentChat != null) {
|
|
||||||
downloadPhotos = preferences.getInt("photo_download_chat2", 0);
|
|
||||||
downloadAudios = preferences.getInt("audio_download_chat2", 0);
|
|
||||||
} else {
|
|
||||||
downloadPhotos = preferences.getInt("photo_download_user2", 0);
|
|
||||||
downloadAudios = preferences.getInt("audio_download_user2", 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
prepareLayouts(move);
|
prepareLayouts(move);
|
||||||
updateSubtitle();
|
updateSubtitle();
|
||||||
checkAndUpdateAvatar();
|
checkAndUpdateAvatar();
|
||||||
@ -786,7 +774,7 @@ public class PopupNotificationActivity extends Activity implements NotificationC
|
|||||||
if (printString == null || printString.length() == 0) {
|
if (printString == null || printString.length() == 0) {
|
||||||
lastPrintString = null;
|
lastPrintString = null;
|
||||||
setTypingAnimation(false);
|
setTypingAnimation(false);
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(currentUser.id);
|
TLRPC.User user = MessagesController.getInstance().getUser(currentUser.id);
|
||||||
if (user != null) {
|
if (user != null) {
|
||||||
currentUser = user;
|
currentUser = user;
|
||||||
}
|
}
|
||||||
@ -802,7 +790,7 @@ public class PopupNotificationActivity extends Activity implements NotificationC
|
|||||||
TLRPC.FileLocation newPhoto = null;
|
TLRPC.FileLocation newPhoto = null;
|
||||||
int placeHolderId = 0;
|
int placeHolderId = 0;
|
||||||
if (currentChat != null) {
|
if (currentChat != null) {
|
||||||
TLRPC.Chat chat = MessagesController.getInstance().chats.get(currentChat.id);
|
TLRPC.Chat chat = MessagesController.getInstance().getChat(currentChat.id);
|
||||||
if (chat == null) {
|
if (chat == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -812,7 +800,7 @@ public class PopupNotificationActivity extends Activity implements NotificationC
|
|||||||
}
|
}
|
||||||
placeHolderId = Utilities.getGroupAvatarForId(currentChat.id);
|
placeHolderId = Utilities.getGroupAvatarForId(currentChat.id);
|
||||||
} else if (currentUser != null) {
|
} else if (currentUser != null) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(currentUser.id);
|
TLRPC.User user = MessagesController.getInstance().getUser(currentUser.id);
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -878,12 +866,12 @@ public class PopupNotificationActivity extends Activity implements NotificationC
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, Object... args) {
|
public void didReceivedNotification(int id, Object... args) {
|
||||||
if (id == 1234) {
|
if (id == NotificationCenter.appDidLogout) {
|
||||||
onFinish();
|
onFinish();
|
||||||
finish();
|
finish();
|
||||||
} else if (id == NotificationsController.pushMessagesUpdated) {
|
} else if (id == NotificationCenter.pushMessagesUpdated) {
|
||||||
getNewMessage();
|
getNewMessage();
|
||||||
} else if (id == MessagesController.updateInterfaces) {
|
} else if (id == NotificationCenter.updateInterfaces) {
|
||||||
if (currentMessageObject == null) {
|
if (currentMessageObject == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -900,7 +888,7 @@ public class PopupNotificationActivity extends Activity implements NotificationC
|
|||||||
updateSubtitle();
|
updateSubtitle();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == MediaController.audioDidReset) {
|
} else if (id == NotificationCenter.audioDidReset) {
|
||||||
Integer mid = (Integer)args[0];
|
Integer mid = (Integer)args[0];
|
||||||
if (messageContainer != null) {
|
if (messageContainer != null) {
|
||||||
int count = messageContainer.getChildCount();
|
int count = messageContainer.getChildCount();
|
||||||
@ -915,7 +903,7 @@ public class PopupNotificationActivity extends Activity implements NotificationC
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == MediaController.audioProgressDidChanged) {
|
} else if (id == NotificationCenter.audioProgressDidChanged) {
|
||||||
Integer mid = (Integer)args[0];
|
Integer mid = (Integer)args[0];
|
||||||
if (messageContainer != null) {
|
if (messageContainer != null) {
|
||||||
int count = messageContainer.getChildCount();
|
int count = messageContainer.getChildCount();
|
||||||
@ -930,7 +918,7 @@ public class PopupNotificationActivity extends Activity implements NotificationC
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == 999) {
|
} else if (id == NotificationCenter.emojiDidLoaded) {
|
||||||
if (messageContainer != null) {
|
if (messageContainer != null) {
|
||||||
int count = messageContainer.getChildCount();
|
int count = messageContainer.getChildCount();
|
||||||
for (int a = 0; a < count; a++) {
|
for (int a = 0; a < count; a++) {
|
||||||
@ -938,7 +926,7 @@ public class PopupNotificationActivity extends Activity implements NotificationC
|
|||||||
view.invalidate();
|
view.invalidate();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.contactsDidLoaded) {
|
} else if (id == NotificationCenter.contactsDidLoaded) {
|
||||||
updateSubtitle();
|
updateSubtitle();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -957,13 +945,13 @@ public class PopupNotificationActivity extends Activity implements NotificationC
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
finished = true;
|
finished = true;
|
||||||
NotificationCenter.getInstance().removeObserver(this, 1234);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.appDidLogout);
|
||||||
NotificationCenter.getInstance().removeObserver(this, NotificationsController.pushMessagesUpdated);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.pushMessagesUpdated);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.updateInterfaces);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MediaController.audioProgressDidChanged);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.audioProgressDidChanged);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MediaController.audioDidReset);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.audioDidReset);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.contactsDidLoaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.contactsDidLoaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, 999);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.emojiDidLoaded);
|
||||||
if (chatActivityEnterView != null) {
|
if (chatActivityEnterView != null) {
|
||||||
chatActivityEnterView.onDestroy();
|
chatActivityEnterView.onDestroy();
|
||||||
}
|
}
|
||||||
|
@ -27,10 +27,11 @@ import android.widget.ListView;
|
|||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
|
import org.telegram.android.MessagesStorage;
|
||||||
import org.telegram.messenger.ConnectionsManager;
|
import org.telegram.messenger.ConnectionsManager;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.android.LocaleController;
|
import org.telegram.android.LocaleController;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.RPCRequest;
|
import org.telegram.messenger.RPCRequest;
|
||||||
import org.telegram.messenger.TLObject;
|
import org.telegram.messenger.TLObject;
|
||||||
@ -62,14 +63,14 @@ public class ProfileNotificationsActivity extends BaseFragment implements Notifi
|
|||||||
settingsVibrateRow = rowCount++;
|
settingsVibrateRow = rowCount++;
|
||||||
settingsLedRow = rowCount++;
|
settingsLedRow = rowCount++;
|
||||||
settingsSoundRow = rowCount++;
|
settingsSoundRow = rowCount++;
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.notificationsSettingsUpdated);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.notificationsSettingsUpdated);
|
||||||
return super.onFragmentCreate();
|
return super.onFragmentCreate();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onFragmentDestroy() {
|
public void onFragmentDestroy() {
|
||||||
super.onFragmentDestroy();
|
super.onFragmentDestroy();
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.notificationsSettingsUpdated);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.notificationsSettingsUpdated);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -96,7 +97,40 @@ public class ProfileNotificationsActivity extends BaseFragment implements Notifi
|
|||||||
listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
|
listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onItemClick(AdapterView<?> adapterView, View view, final int i, long l) {
|
public void onItemClick(AdapterView<?> adapterView, View view, final int i, long l) {
|
||||||
if (i == settingsVibrateRow || i == settingsNotificationsRow) {
|
if (i == settingsVibrateRow) {
|
||||||
|
AlertDialog.Builder builder = new AlertDialog.Builder(getParentActivity());
|
||||||
|
builder.setTitle(LocaleController.getString("Vibrate", R.string.Vibrate));
|
||||||
|
builder.setItems(new CharSequence[] {
|
||||||
|
LocaleController.getString("Disabled", R.string.Disabled),
|
||||||
|
LocaleController.getString("SettingsDefault", R.string.SettingsDefault),
|
||||||
|
LocaleController.getString("SystemDefault", R.string.SystemDefault),
|
||||||
|
LocaleController.getString("Short", R.string.Short),
|
||||||
|
LocaleController.getString("Long", R.string.Long)
|
||||||
|
}, new DialogInterface.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
|
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("Notifications", Activity.MODE_PRIVATE);
|
||||||
|
SharedPreferences.Editor editor = preferences.edit();
|
||||||
|
if (which == 0) {
|
||||||
|
editor.putInt("vibrate_" + dialog_id, 2);
|
||||||
|
} else if (which == 1) {
|
||||||
|
editor.putInt("vibrate_" + dialog_id, 0);
|
||||||
|
} else if (which == 2) {
|
||||||
|
editor.putInt("vibrate_" + dialog_id, 4);
|
||||||
|
} else if (which == 3) {
|
||||||
|
editor.putInt("vibrate_" + dialog_id, 1);
|
||||||
|
} else if (which == 4) {
|
||||||
|
editor.putInt("vibrate_" + dialog_id, 3);
|
||||||
|
}
|
||||||
|
editor.commit();
|
||||||
|
if (listView != null) {
|
||||||
|
listView.invalidateViews();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
builder.setNegativeButton(LocaleController.getString("Cancel", R.string.Cancel), null);
|
||||||
|
showAlertDialog(builder);
|
||||||
|
} else if (i == settingsNotificationsRow) {
|
||||||
if (getParentActivity() == null) {
|
if (getParentActivity() == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -111,11 +145,8 @@ public class ProfileNotificationsActivity extends BaseFragment implements Notifi
|
|||||||
public void onClick(DialogInterface dialog, int which) {
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("Notifications", Activity.MODE_PRIVATE);
|
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("Notifications", Activity.MODE_PRIVATE);
|
||||||
SharedPreferences.Editor editor = preferences.edit();
|
SharedPreferences.Editor editor = preferences.edit();
|
||||||
if (i == settingsVibrateRow) {
|
|
||||||
editor.putInt("vibrate_" + dialog_id, which);
|
|
||||||
} else if (i == settingsNotificationsRow) {
|
|
||||||
editor.putInt("notify2_" + dialog_id, which);
|
editor.putInt("notify2_" + dialog_id, which);
|
||||||
}
|
MessagesStorage.getInstance().setDialogFlags(dialog_id, which == 2 ? 1 : 0);
|
||||||
editor.commit();
|
editor.commit();
|
||||||
if (listView != null) {
|
if (listView != null) {
|
||||||
listView.invalidateViews();
|
listView.invalidateViews();
|
||||||
@ -240,7 +271,7 @@ public class ProfileNotificationsActivity extends BaseFragment implements Notifi
|
|||||||
((TLRPC.TL_inputNotifyPeer)req.peer).peer = new TLRPC.TL_inputPeerChat();
|
((TLRPC.TL_inputNotifyPeer)req.peer).peer = new TLRPC.TL_inputPeerChat();
|
||||||
((TLRPC.TL_inputNotifyPeer)req.peer).peer.chat_id = -(int)dialog_id;
|
((TLRPC.TL_inputNotifyPeer)req.peer).peer.chat_id = -(int)dialog_id;
|
||||||
} else {
|
} else {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get((int)dialog_id);
|
TLRPC.User user = MessagesController.getInstance().getUser((int)dialog_id);
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -300,7 +331,7 @@ public class ProfileNotificationsActivity extends BaseFragment implements Notifi
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, Object... args) {
|
public void didReceivedNotification(int id, Object... args) {
|
||||||
if (id == MessagesController.notificationsSettingsUpdated) {
|
if (id == NotificationCenter.notificationsSettingsUpdated) {
|
||||||
listView.invalidateViews();
|
listView.invalidateViews();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -360,11 +391,15 @@ public class ProfileNotificationsActivity extends BaseFragment implements Notifi
|
|||||||
SharedPreferences preferences = mContext.getSharedPreferences("Notifications", Activity.MODE_PRIVATE);
|
SharedPreferences preferences = mContext.getSharedPreferences("Notifications", Activity.MODE_PRIVATE);
|
||||||
int value = preferences.getInt("vibrate_" + dialog_id, 0);
|
int value = preferences.getInt("vibrate_" + dialog_id, 0);
|
||||||
if (value == 0) {
|
if (value == 0) {
|
||||||
detailTextView.setText(LocaleController.getString("Default", R.string.Default));
|
detailTextView.setText(LocaleController.getString("SettingsDefault", R.string.SettingsDefault));
|
||||||
} else if (value == 1) {
|
} else if (value == 1) {
|
||||||
detailTextView.setText(LocaleController.getString("Enabled", R.string.Enabled));
|
detailTextView.setText(LocaleController.getString("Short", R.string.Short));
|
||||||
} else if (value == 2) {
|
} else if (value == 2) {
|
||||||
detailTextView.setText(LocaleController.getString("Disabled", R.string.Disabled));
|
detailTextView.setText(LocaleController.getString("Disabled", R.string.Disabled));
|
||||||
|
} else if (value == 3) {
|
||||||
|
detailTextView.setText(LocaleController.getString("Long", R.string.Long));
|
||||||
|
} else if (value == 4) {
|
||||||
|
detailTextView.setText(LocaleController.getString("SystemDefault", R.string.SystemDefault));
|
||||||
}
|
}
|
||||||
} else if (i == settingsNotificationsRow) {
|
} else if (i == settingsNotificationsRow) {
|
||||||
textView.setText(LocaleController.getString("Notifications", R.string.Notifications));
|
textView.setText(LocaleController.getString("Notifications", R.string.Notifications));
|
||||||
|
@ -37,6 +37,7 @@ import android.widget.Toast;
|
|||||||
import org.telegram.android.AndroidUtilities;
|
import org.telegram.android.AndroidUtilities;
|
||||||
import org.telegram.android.ContactsController;
|
import org.telegram.android.ContactsController;
|
||||||
import org.telegram.PhoneFormat.PhoneFormat;
|
import org.telegram.PhoneFormat.PhoneFormat;
|
||||||
|
import org.telegram.android.MediaController;
|
||||||
import org.telegram.messenger.BuildVars;
|
import org.telegram.messenger.BuildVars;
|
||||||
import org.telegram.android.LocaleController;
|
import org.telegram.android.LocaleController;
|
||||||
import org.telegram.messenger.SerializedData;
|
import org.telegram.messenger.SerializedData;
|
||||||
@ -47,13 +48,13 @@ import org.telegram.messenger.ConnectionsManager;
|
|||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
import org.telegram.android.MessagesStorage;
|
import org.telegram.android.MessagesStorage;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.RPCRequest;
|
import org.telegram.messenger.RPCRequest;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.objects.MessageObject;
|
import org.telegram.android.MessageObject;
|
||||||
import org.telegram.objects.PhotoObject;
|
import org.telegram.android.PhotoObject;
|
||||||
import org.telegram.ui.Adapters.BaseFragmentAdapter;
|
import org.telegram.ui.Adapters.BaseFragmentAdapter;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
||||||
import org.telegram.ui.Views.AvatarUpdater;
|
import org.telegram.ui.Views.AvatarUpdater;
|
||||||
@ -87,12 +88,10 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
private int messagesSectionRow;
|
private int messagesSectionRow;
|
||||||
private int sendByEnterRow;
|
private int sendByEnterRow;
|
||||||
private int terminateSessionsRow;
|
private int terminateSessionsRow;
|
||||||
private int photoDownloadSection;
|
private int mediaDownloadSection;
|
||||||
private int photoDownloadChatRow;
|
private int mobileDownloadRow;
|
||||||
private int photoDownloadPrivateRow;
|
private int wifiDownloadRow;
|
||||||
private int audioDownloadSection;
|
private int roamingDownloadRow;
|
||||||
private int audioDownloadChatRow;
|
|
||||||
private int audioDownloadPrivateRow;
|
|
||||||
private int telegramFaqRow;
|
private int telegramFaqRow;
|
||||||
private int languageRow;
|
private int languageRow;
|
||||||
private int versionRow;
|
private int versionRow;
|
||||||
@ -129,13 +128,13 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
@Override
|
@Override
|
||||||
public void run(TLObject response, TLRPC.TL_error error) {
|
public void run(TLObject response, TLRPC.TL_error error) {
|
||||||
if (error == null) {
|
if (error == null) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(UserConfig.getClientUserId());
|
TLRPC.User user = MessagesController.getInstance().getUser(UserConfig.getClientUserId());
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
user = UserConfig.getCurrentUser();
|
user = UserConfig.getCurrentUser();
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
MessagesController.getInstance().users.put(user.id, user);
|
MessagesController.getInstance().putUser(user, false);
|
||||||
} else {
|
} else {
|
||||||
UserConfig.setCurrentUser(user);
|
UserConfig.setCurrentUser(user);
|
||||||
}
|
}
|
||||||
@ -160,10 +159,10 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
ArrayList<TLRPC.User> users = new ArrayList<TLRPC.User>();
|
ArrayList<TLRPC.User> users = new ArrayList<TLRPC.User>();
|
||||||
users.add(user);
|
users.add(user);
|
||||||
MessagesStorage.getInstance().putUsersAndChats(users, null, false, true);
|
MessagesStorage.getInstance().putUsersAndChats(users, null, false, true);
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.updateInterfaces, MessagesController.UPDATE_MASK_ALL);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.updateInterfaces, MessagesController.UPDATE_MASK_ALL);
|
||||||
UserConfig.saveConfig(true);
|
UserConfig.saveConfig(true);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -172,7 +171,7 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.updateInterfaces);
|
||||||
|
|
||||||
|
|
||||||
rowCount = 0;
|
rowCount = 0;
|
||||||
@ -186,12 +185,10 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
blockedRow = rowCount++;
|
blockedRow = rowCount++;
|
||||||
backgroundRow = rowCount++;
|
backgroundRow = rowCount++;
|
||||||
terminateSessionsRow = rowCount++;
|
terminateSessionsRow = rowCount++;
|
||||||
photoDownloadSection = rowCount++;
|
mediaDownloadSection = rowCount++;
|
||||||
photoDownloadChatRow = rowCount++;
|
mobileDownloadRow = rowCount++;
|
||||||
photoDownloadPrivateRow = rowCount++;
|
wifiDownloadRow = rowCount++;
|
||||||
audioDownloadSection = rowCount++;
|
roamingDownloadRow = rowCount++;
|
||||||
audioDownloadChatRow = rowCount++;
|
|
||||||
audioDownloadPrivateRow = rowCount++;
|
|
||||||
messagesSectionRow = rowCount++;
|
messagesSectionRow = rowCount++;
|
||||||
textSizeRow = rowCount++;
|
textSizeRow = rowCount++;
|
||||||
sendByEnterRow = rowCount++;
|
sendByEnterRow = rowCount++;
|
||||||
@ -215,7 +212,7 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
@Override
|
@Override
|
||||||
public void onFragmentDestroy() {
|
public void onFragmentDestroy() {
|
||||||
super.onFragmentDestroy();
|
super.onFragmentDestroy();
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.updateInterfaces);
|
||||||
avatarUpdater.clear();
|
avatarUpdater.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -343,7 +340,7 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
ConnectionsManager.getInstance().performRpc(req, new RPCRequest.RPCRequestDelegate() {
|
ConnectionsManager.getInstance().performRpc(req, new RPCRequest.RPCRequestDelegate() {
|
||||||
@Override
|
@Override
|
||||||
public void run(final TLObject response, final TLRPC.TL_error error) {
|
public void run(final TLObject response, final TLRPC.TL_error error) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
if (getParentActivity() == null) {
|
if (getParentActivity() == null) {
|
||||||
@ -419,29 +416,66 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
});
|
});
|
||||||
builder.setNegativeButton(LocaleController.getString("Cancel", R.string.Cancel), null);
|
builder.setNegativeButton(LocaleController.getString("Cancel", R.string.Cancel), null);
|
||||||
showAlertDialog(builder);
|
showAlertDialog(builder);
|
||||||
} else if (i == photoDownloadChatRow || i == photoDownloadPrivateRow || i == audioDownloadChatRow || i == audioDownloadPrivateRow) {
|
} else if (i == wifiDownloadRow || i == mobileDownloadRow || i == roamingDownloadRow) {
|
||||||
if (getParentActivity() == null) {
|
if (getParentActivity() == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
AlertDialog.Builder builder = new AlertDialog.Builder(getParentActivity());
|
AlertDialog.Builder builder = new AlertDialog.Builder(getParentActivity());
|
||||||
builder.setTitle(LocaleController.getString("AppName", R.string.AppName));
|
|
||||||
builder.setItems(new CharSequence[] {
|
int mask = 0;
|
||||||
LocaleController.getString("Enabled", R.string.Enabled),
|
if (i == mobileDownloadRow) {
|
||||||
LocaleController.getString("Disabled", R.string.Disabled),
|
builder.setTitle(LocaleController.getString("WhenUsingMobileData", R.string.WhenUsingMobileData));
|
||||||
LocaleController.getString("WiFiOnly", R.string.WiFiOnly)
|
mask = MediaController.getInstance().mobileDataDownloadMask;
|
||||||
}, new DialogInterface.OnClickListener() {
|
} else if (i == wifiDownloadRow) {
|
||||||
|
builder.setTitle(LocaleController.getString("WhenConnectedOnWiFi", R.string.WhenConnectedOnWiFi));
|
||||||
|
mask = MediaController.getInstance().wifiDownloadMask;
|
||||||
|
} else if (i == roamingDownloadRow) {
|
||||||
|
builder.setTitle(LocaleController.getString("WhenRoaming", R.string.WhenRoaming));
|
||||||
|
mask = MediaController.getInstance().roamingDownloadMask;
|
||||||
|
}
|
||||||
|
builder.setMultiChoiceItems(
|
||||||
|
new CharSequence[]{LocaleController.getString("AttachPhoto", R.string.AttachPhoto), LocaleController.getString("AttachAudio", R.string.AttachAudio), LocaleController.getString("AttachAudio", R.string.AttachVideo), LocaleController.getString("AttachAudio", R.string.AttachDocument)},
|
||||||
|
new boolean[]{(mask & MediaController.AUTODOWNLOAD_MASK_PHOTO) != 0, (mask & MediaController.AUTODOWNLOAD_MASK_AUDIO) != 0, (mask & MediaController.AUTODOWNLOAD_MASK_VIDEO) != 0, (mask & MediaController.AUTODOWNLOAD_MASK_DOCUMENT) != 0},
|
||||||
|
new DialogInterface.OnMultiChoiceClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
public void onClick(DialogInterface dialog, int which, boolean isChecked) {
|
||||||
|
int mask = 0;
|
||||||
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("mainconfig", Activity.MODE_PRIVATE);
|
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("mainconfig", Activity.MODE_PRIVATE);
|
||||||
SharedPreferences.Editor editor = preferences.edit();
|
SharedPreferences.Editor editor = preferences.edit();
|
||||||
if (i == photoDownloadChatRow) {
|
if (i == mobileDownloadRow) {
|
||||||
editor.putInt("photo_download_chat2", which);
|
mask = MediaController.getInstance().mobileDataDownloadMask;
|
||||||
} else if (i == photoDownloadPrivateRow) {
|
} else if (i == wifiDownloadRow) {
|
||||||
editor.putInt("photo_download_user2", which);
|
mask = MediaController.getInstance().wifiDownloadMask;
|
||||||
} else if (i == audioDownloadChatRow) {
|
} else if (i == roamingDownloadRow) {
|
||||||
editor.putInt("audio_download_chat2", which);
|
mask = MediaController.getInstance().roamingDownloadMask;
|
||||||
} else if (i == audioDownloadPrivateRow) {
|
}
|
||||||
editor.putInt("audio_download_user2", which);
|
|
||||||
|
int maskDiff = 0;
|
||||||
|
if (which == 0) {
|
||||||
|
maskDiff = MediaController.AUTODOWNLOAD_MASK_PHOTO;
|
||||||
|
} else if (which == 1) {
|
||||||
|
maskDiff = MediaController.AUTODOWNLOAD_MASK_AUDIO;
|
||||||
|
} else if (which == 2) {
|
||||||
|
maskDiff = MediaController.AUTODOWNLOAD_MASK_VIDEO;
|
||||||
|
} else if (which == 3) {
|
||||||
|
maskDiff = MediaController.AUTODOWNLOAD_MASK_DOCUMENT;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isChecked) {
|
||||||
|
mask |= maskDiff;
|
||||||
|
} else {
|
||||||
|
mask &= ~maskDiff;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (i == mobileDownloadRow) {
|
||||||
|
editor.putInt("mobileDataDownloadMask", mask);
|
||||||
|
mask = MediaController.getInstance().mobileDataDownloadMask = mask;
|
||||||
|
} else if (i == wifiDownloadRow) {
|
||||||
|
editor.putInt("wifiDownloadMask", mask);
|
||||||
|
MediaController.getInstance().wifiDownloadMask = mask;
|
||||||
|
} else if (i == roamingDownloadRow) {
|
||||||
|
editor.putInt("roamingDownloadMask", mask);
|
||||||
|
MediaController.getInstance().roamingDownloadMask = mask;
|
||||||
}
|
}
|
||||||
editor.commit();
|
editor.commit();
|
||||||
if (listView != null) {
|
if (listView != null) {
|
||||||
@ -449,7 +483,7 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
builder.setNegativeButton(LocaleController.getString("Cancel", R.string.Cancel), null);
|
builder.setNegativeButton(LocaleController.getString("OK", R.string.OK), null);
|
||||||
showAlertDialog(builder);
|
showAlertDialog(builder);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -463,12 +497,17 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
return fragmentView;
|
return fragmentView;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onDialogDismiss() {
|
||||||
|
MediaController.getInstance().checkAutodownloadSettings();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public PhotoViewer.PlaceProviderObject getPlaceForPhoto(MessageObject messageObject, TLRPC.FileLocation fileLocation, int index) {
|
public PhotoViewer.PlaceProviderObject getPlaceForPhoto(MessageObject messageObject, TLRPC.FileLocation fileLocation, int index) {
|
||||||
if (fileLocation == null) {
|
if (fileLocation == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(UserConfig.getClientUserId());
|
TLRPC.User user = MessagesController.getInstance().getUser(UserConfig.getClientUserId());
|
||||||
if (user != null && user.photo != null && user.photo.photo_big != null) {
|
if (user != null && user.photo != null && user.photo.photo_big != null) {
|
||||||
TLRPC.FileLocation photoBig = user.photo.photo_big;
|
TLRPC.FileLocation photoBig = user.photo.photo_big;
|
||||||
if (photoBig.local_id == fileLocation.local_id && photoBig.volume_id == fileLocation.volume_id && photoBig.dc_id == fileLocation.dc_id) {
|
if (photoBig.local_id == fileLocation.local_id && photoBig.volume_id == fileLocation.volume_id && photoBig.dc_id == fileLocation.dc_id) {
|
||||||
@ -521,7 +560,7 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
int uid = preferences.getInt("support_id", 0);
|
int uid = preferences.getInt("support_id", 0);
|
||||||
TLRPC.User supportUser = null;
|
TLRPC.User supportUser = null;
|
||||||
if (uid != 0) {
|
if (uid != 0) {
|
||||||
supportUser = MessagesController.getInstance().users.get(uid);
|
supportUser = MessagesController.getInstance().getUser(uid);
|
||||||
if (supportUser == null) {
|
if (supportUser == null) {
|
||||||
String userString = preferences.getString("support_user", null);
|
String userString = preferences.getString("support_user", null);
|
||||||
if (userString != null) {
|
if (userString != null) {
|
||||||
@ -554,7 +593,7 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
if (error == null) {
|
if (error == null) {
|
||||||
|
|
||||||
final TLRPC.TL_help_support res = (TLRPC.TL_help_support)response;
|
final TLRPC.TL_help_support res = (TLRPC.TL_help_support)response;
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
SharedPreferences.Editor editor = preferences.edit();
|
SharedPreferences.Editor editor = preferences.edit();
|
||||||
@ -571,14 +610,14 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
ArrayList<TLRPC.User> users = new ArrayList<TLRPC.User>();
|
ArrayList<TLRPC.User> users = new ArrayList<TLRPC.User>();
|
||||||
users.add(res.user);
|
users.add(res.user);
|
||||||
MessagesStorage.getInstance().putUsersAndChats(users, null, true, true);
|
MessagesStorage.getInstance().putUsersAndChats(users, null, true, true);
|
||||||
MessagesController.getInstance().users.put(res.user.id, res.user);
|
MessagesController.getInstance().putUser(res.user, false);
|
||||||
Bundle args = new Bundle();
|
Bundle args = new Bundle();
|
||||||
args.putInt("user_id", res.user.id);
|
args.putInt("user_id", res.user.id);
|
||||||
presentFragment(new ChatActivity(args));
|
presentFragment(new ChatActivity(args));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
try {
|
try {
|
||||||
@ -592,7 +631,7 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
MessagesController.getInstance().users.putIfAbsent(supportUser.id, supportUser);
|
MessagesController.getInstance().putUser(supportUser, true);
|
||||||
Bundle args = new Bundle();
|
Bundle args = new Bundle();
|
||||||
args.putInt("user_id", supportUser.id);
|
args.putInt("user_id", supportUser.id);
|
||||||
presentFragment(new ChatActivity(args));
|
presentFragment(new ChatActivity(args));
|
||||||
@ -620,7 +659,7 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, Object... args) {
|
public void didReceivedNotification(int id, Object... args) {
|
||||||
if (id == MessagesController.updateInterfaces) {
|
if (id == NotificationCenter.updateInterfaces) {
|
||||||
int mask = (Integer)args[0];
|
int mask = (Integer)args[0];
|
||||||
if ((mask & MessagesController.UPDATE_MASK_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_NAME) != 0) {
|
if ((mask & MessagesController.UPDATE_MASK_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_NAME) != 0) {
|
||||||
if (listView != null) {
|
if (listView != null) {
|
||||||
@ -677,8 +716,8 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
@Override
|
@Override
|
||||||
public boolean isEnabled(int i) {
|
public boolean isEnabled(int i) {
|
||||||
return i == textSizeRow || i == enableAnimationsRow || i == blockedRow || i == notificationRow || i == backgroundRow ||
|
return i == textSizeRow || i == enableAnimationsRow || i == blockedRow || i == notificationRow || i == backgroundRow ||
|
||||||
i == askQuestionRow || i == sendLogsRow || i == sendByEnterRow || i == terminateSessionsRow || i == photoDownloadPrivateRow ||
|
i == askQuestionRow || i == sendLogsRow || i == sendByEnterRow || i == terminateSessionsRow || i == wifiDownloadRow ||
|
||||||
i == photoDownloadChatRow || i == clearLogsRow || i == audioDownloadChatRow || i == audioDownloadPrivateRow || i == languageRow ||
|
i == mobileDownloadRow || i == clearLogsRow || i == roamingDownloadRow || i == languageRow ||
|
||||||
i == switchBackendButtonRow || i == telegramFaqRow || i == contactsSortRow || i == contactsReimportRow;
|
i == switchBackendButtonRow || i == telegramFaqRow || i == contactsSortRow || i == contactsReimportRow;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -729,7 +768,7 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
|
|
||||||
CharSequence[] items;
|
CharSequence[] items;
|
||||||
|
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(UserConfig.getClientUserId());
|
TLRPC.User user = MessagesController.getInstance().getUser(UserConfig.getClientUserId());
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
user = UserConfig.getCurrentUser();
|
user = UserConfig.getCurrentUser();
|
||||||
}
|
}
|
||||||
@ -749,7 +788,7 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
@Override
|
@Override
|
||||||
public void onClick(DialogInterface dialogInterface, int i) {
|
public void onClick(DialogInterface dialogInterface, int i) {
|
||||||
if (i == 0 && full) {
|
if (i == 0 && full) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(UserConfig.getClientUserId());
|
TLRPC.User user = MessagesController.getInstance().getUser(UserConfig.getClientUserId());
|
||||||
if (user != null && user.photo != null && user.photo.photo_big != null) {
|
if (user != null && user.photo != null && user.photo.photo_big != null) {
|
||||||
PhotoViewer.getInstance().setParentActivity(getParentActivity());
|
PhotoViewer.getInstance().setParentActivity(getParentActivity());
|
||||||
PhotoViewer.getInstance().openPhoto(user.photo.photo_big, SettingsActivity.this);
|
PhotoViewer.getInstance().openPhoto(user.photo.photo_big, SettingsActivity.this);
|
||||||
@ -759,50 +798,7 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
} else if (i == 1 && !full || i == 2 && full) {
|
} else if (i == 1 && !full || i == 2 && full) {
|
||||||
avatarUpdater.openGallery();
|
avatarUpdater.openGallery();
|
||||||
} else if (i == 3) {
|
} else if (i == 3) {
|
||||||
TLRPC.TL_photos_updateProfilePhoto req = new TLRPC.TL_photos_updateProfilePhoto();
|
MessagesController.getInstance().deleteUserPhoto(null);
|
||||||
req.id = new TLRPC.TL_inputPhotoEmpty();
|
|
||||||
req.crop = new TLRPC.TL_inputPhotoCropAuto();
|
|
||||||
UserConfig.getCurrentUser().photo = new TLRPC.TL_userProfilePhotoEmpty();
|
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(UserConfig.getClientUserId());
|
|
||||||
if (user == null) {
|
|
||||||
user = UserConfig.getCurrentUser();
|
|
||||||
}
|
|
||||||
if (user == null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (user != null) {
|
|
||||||
user.photo = UserConfig.getCurrentUser().photo;
|
|
||||||
}
|
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.updateInterfaces, MessagesController.UPDATE_MASK_ALL);
|
|
||||||
ConnectionsManager.getInstance().performRpc(req, new RPCRequest.RPCRequestDelegate() {
|
|
||||||
@Override
|
|
||||||
public void run(TLObject response, TLRPC.TL_error error) {
|
|
||||||
if (error == null) {
|
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(UserConfig.getClientUserId());
|
|
||||||
if (user == null) {
|
|
||||||
user = UserConfig.getCurrentUser();
|
|
||||||
MessagesController.getInstance().users.put(user.id, user);
|
|
||||||
} else {
|
|
||||||
UserConfig.setCurrentUser(user);
|
|
||||||
}
|
|
||||||
if (user == null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
MessagesStorage.getInstance().clearUserPhotos(user.id);
|
|
||||||
ArrayList<TLRPC.User> users = new ArrayList<TLRPC.User>();
|
|
||||||
users.add(user);
|
|
||||||
MessagesStorage.getInstance().putUsersAndChats(users, null, false, true);
|
|
||||||
user.photo = (TLRPC.UserProfilePhoto)response;
|
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.updateInterfaces, MessagesController.UPDATE_MASK_ALL);
|
|
||||||
UserConfig.saveConfig(true);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -816,7 +812,7 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
textView = (TextView)view.findViewById(R.id.settings_name);
|
textView = (TextView)view.findViewById(R.id.settings_name);
|
||||||
Typeface typeface = AndroidUtilities.getTypeface("fonts/rmedium.ttf");
|
Typeface typeface = AndroidUtilities.getTypeface("fonts/rmedium.ttf");
|
||||||
textView.setTypeface(typeface);
|
textView.setTypeface(typeface);
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(UserConfig.getClientUserId());
|
TLRPC.User user = MessagesController.getInstance().getUser(UserConfig.getClientUserId());
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
user = UserConfig.getCurrentUser();
|
user = UserConfig.getCurrentUser();
|
||||||
}
|
}
|
||||||
@ -848,10 +844,8 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
textView.setText(LocaleController.getString("Support", R.string.Support));
|
textView.setText(LocaleController.getString("Support", R.string.Support));
|
||||||
} else if (i == messagesSectionRow) {
|
} else if (i == messagesSectionRow) {
|
||||||
textView.setText(LocaleController.getString("MessagesSettings", R.string.MessagesSettings));
|
textView.setText(LocaleController.getString("MessagesSettings", R.string.MessagesSettings));
|
||||||
} else if (i == photoDownloadSection) {
|
} else if (i == mediaDownloadSection) {
|
||||||
textView.setText(LocaleController.getString("AutomaticPhotoDownload", R.string.AutomaticPhotoDownload));
|
textView.setText(LocaleController.getString("AutomaticMediaDownload", R.string.AutomaticMediaDownload));
|
||||||
} else if (i == audioDownloadSection) {
|
|
||||||
textView.setText(LocaleController.getString("AutomaticAudioDownload", R.string.AutomaticAudioDownload));
|
|
||||||
} else if (i == contactsSectionRow) {
|
} else if (i == contactsSectionRow) {
|
||||||
textView.setText(LocaleController.getString("Contacts", R.string.Contacts).toUpperCase());
|
textView.setText(LocaleController.getString("Contacts", R.string.Contacts).toUpperCase());
|
||||||
}
|
}
|
||||||
@ -961,7 +955,7 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("Notifications", Activity.MODE_PRIVATE);
|
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("Notifications", Activity.MODE_PRIVATE);
|
||||||
SharedPreferences.Editor editor = preferences.edit();
|
SharedPreferences.Editor editor = preferences.edit();
|
||||||
editor.clear().commit();
|
editor.clear().commit();
|
||||||
NotificationCenter.getInstance().postNotificationName(1234);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.appDidLogout);
|
||||||
MessagesController.getInstance().unregistedPush();
|
MessagesController.getInstance().unregistedPush();
|
||||||
MessagesController.getInstance().logOut();
|
MessagesController.getInstance().logOut();
|
||||||
UserConfig.clearConfig();
|
UserConfig.clearConfig();
|
||||||
@ -1005,54 +999,6 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
} else if (sort == 2) {
|
} else if (sort == 2) {
|
||||||
detailTextView.setText(LocaleController.getString("LastName", R.string.SortLastName));
|
detailTextView.setText(LocaleController.getString("LastName", R.string.SortLastName));
|
||||||
}
|
}
|
||||||
} else if (i == photoDownloadChatRow) {
|
|
||||||
textView.setText(LocaleController.getString("AutomaticPhotoDownloadGroups", R.string.AutomaticPhotoDownloadGroups));
|
|
||||||
divider.setVisibility(View.VISIBLE);
|
|
||||||
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("mainconfig", Activity.MODE_PRIVATE);
|
|
||||||
int value = preferences.getInt("photo_download_chat2", 0);
|
|
||||||
if (value == 0) {
|
|
||||||
detailTextView.setText(LocaleController.getString("Enabled", R.string.Enabled));
|
|
||||||
} else if (value == 1) {
|
|
||||||
detailTextView.setText(LocaleController.getString("Disabled", R.string.Disabled));
|
|
||||||
} else if (value == 2) {
|
|
||||||
detailTextView.setText(LocaleController.getString("WiFiOnly", R.string.WiFiOnly));
|
|
||||||
}
|
|
||||||
} else if (i == photoDownloadPrivateRow) {
|
|
||||||
textView.setText(LocaleController.getString("AutomaticPhotoDownloadPrivateChats", R.string.AutomaticPhotoDownloadPrivateChats));
|
|
||||||
divider.setVisibility(View.INVISIBLE);
|
|
||||||
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("mainconfig", Activity.MODE_PRIVATE);
|
|
||||||
int value = preferences.getInt("photo_download_user2", 0);
|
|
||||||
if (value == 0) {
|
|
||||||
detailTextView.setText(LocaleController.getString("Enabled", R.string.Enabled));
|
|
||||||
} else if (value == 1) {
|
|
||||||
detailTextView.setText(LocaleController.getString("Disabled", R.string.Disabled));
|
|
||||||
} else if (value == 2) {
|
|
||||||
detailTextView.setText(LocaleController.getString("WiFiOnly", R.string.WiFiOnly));
|
|
||||||
}
|
|
||||||
} else if (i == audioDownloadChatRow) {
|
|
||||||
textView.setText(LocaleController.getString("AutomaticPhotoDownloadGroups", R.string.AutomaticPhotoDownloadGroups));
|
|
||||||
divider.setVisibility(View.VISIBLE);
|
|
||||||
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("mainconfig", Activity.MODE_PRIVATE);
|
|
||||||
int value = preferences.getInt("audio_download_chat2", 0);
|
|
||||||
if (value == 0) {
|
|
||||||
detailTextView.setText(LocaleController.getString("Enabled", R.string.Enabled));
|
|
||||||
} else if (value == 1) {
|
|
||||||
detailTextView.setText(LocaleController.getString("Disabled", R.string.Disabled));
|
|
||||||
} else if (value == 2) {
|
|
||||||
detailTextView.setText(LocaleController.getString("WiFiOnly", R.string.WiFiOnly));
|
|
||||||
}
|
|
||||||
} else if (i == audioDownloadPrivateRow) {
|
|
||||||
textView.setText(LocaleController.getString("AutomaticPhotoDownloadPrivateChats", R.string.AutomaticPhotoDownloadPrivateChats));
|
|
||||||
divider.setVisibility(View.INVISIBLE);
|
|
||||||
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("mainconfig", Activity.MODE_PRIVATE);
|
|
||||||
int value = preferences.getInt("audio_download_user2", 0);
|
|
||||||
if (value == 0) {
|
|
||||||
detailTextView.setText(LocaleController.getString("Enabled", R.string.Enabled));
|
|
||||||
} else if (value == 1) {
|
|
||||||
detailTextView.setText(LocaleController.getString("Disabled", R.string.Disabled));
|
|
||||||
} else if (value == 2) {
|
|
||||||
detailTextView.setText(LocaleController.getString("WiFiOnly", R.string.WiFiOnly));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} else if (type == 6) {
|
} else if (type == 6) {
|
||||||
if (view == null) {
|
if (view == null) {
|
||||||
@ -1066,6 +1012,56 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else if (type == 7) {
|
||||||
|
if (view == null) {
|
||||||
|
LayoutInflater li = (LayoutInflater)mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
|
||||||
|
view = li.inflate(R.layout.settings_row_detail_layout, viewGroup, false);
|
||||||
|
}
|
||||||
|
TextView textView = (TextView)view.findViewById(R.id.settings_row_text);
|
||||||
|
TextView textViewDetail = (TextView)view.findViewById(R.id.settings_row_text_detail);
|
||||||
|
View divider = view.findViewById(R.id.settings_row_divider);
|
||||||
|
|
||||||
|
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("mainconfig", Activity.MODE_PRIVATE);
|
||||||
|
int mask = 0;
|
||||||
|
if (i == mobileDownloadRow) {
|
||||||
|
textView.setText(LocaleController.getString("WhenUsingMobileData", R.string.WhenUsingMobileData));
|
||||||
|
divider.setVisibility(View.VISIBLE);
|
||||||
|
mask = MediaController.getInstance().mobileDataDownloadMask;
|
||||||
|
} else if (i == wifiDownloadRow) {
|
||||||
|
textView.setText(LocaleController.getString("WhenConnectedOnWiFi", R.string.WhenConnectedOnWiFi));
|
||||||
|
divider.setVisibility(View.VISIBLE);
|
||||||
|
mask = MediaController.getInstance().wifiDownloadMask;
|
||||||
|
} else if (i == roamingDownloadRow) {
|
||||||
|
textView.setText(LocaleController.getString("WhenRoaming", R.string.WhenRoaming));
|
||||||
|
divider.setVisibility(View.GONE);
|
||||||
|
mask = MediaController.getInstance().roamingDownloadMask;
|
||||||
|
}
|
||||||
|
String text = "";
|
||||||
|
if ((mask & MediaController.AUTODOWNLOAD_MASK_PHOTO) != 0) {
|
||||||
|
text += LocaleController.getString("AttachPhoto", R.string.AttachPhoto);
|
||||||
|
}
|
||||||
|
if ((mask & MediaController.AUTODOWNLOAD_MASK_AUDIO) != 0) {
|
||||||
|
if (text.length() != 0) {
|
||||||
|
text += ", ";
|
||||||
|
}
|
||||||
|
text += LocaleController.getString("AttachAudio", R.string.AttachAudio);
|
||||||
|
}
|
||||||
|
if ((mask & MediaController.AUTODOWNLOAD_MASK_VIDEO) != 0) {
|
||||||
|
if (text.length() != 0) {
|
||||||
|
text += ", ";
|
||||||
|
}
|
||||||
|
text += LocaleController.getString("AttachVideo", R.string.AttachVideo);
|
||||||
|
}
|
||||||
|
if ((mask & MediaController.AUTODOWNLOAD_MASK_DOCUMENT) != 0) {
|
||||||
|
if (text.length() != 0) {
|
||||||
|
text += ", ";
|
||||||
|
}
|
||||||
|
text += LocaleController.getString("AttachDocument", R.string.AttachDocument);
|
||||||
|
}
|
||||||
|
if (text.length() == 0) {
|
||||||
|
text = LocaleController.getString("NoMediaAutoDownload", R.string.NoMediaAutoDownload);
|
||||||
|
}
|
||||||
|
textViewDetail.setText(text);
|
||||||
}
|
}
|
||||||
return view;
|
return view;
|
||||||
}
|
}
|
||||||
@ -1074,9 +1070,9 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
public int getItemViewType(int i) {
|
public int getItemViewType(int i) {
|
||||||
if (i == profileRow) {
|
if (i == profileRow) {
|
||||||
return 0;
|
return 0;
|
||||||
} else if (i == numberSectionRow || i == settingsSectionRow || i == supportSectionRow || i == messagesSectionRow || i == photoDownloadSection || i == audioDownloadSection || i == contactsSectionRow) {
|
} else if (i == numberSectionRow || i == settingsSectionRow || i == supportSectionRow || i == messagesSectionRow || i == mediaDownloadSection || i == contactsSectionRow) {
|
||||||
return 1;
|
return 1;
|
||||||
} else if (i == textSizeRow || i == languageRow || i == contactsSortRow || i == photoDownloadChatRow || i == photoDownloadPrivateRow || i == audioDownloadChatRow || i == audioDownloadPrivateRow) {
|
} else if (i == textSizeRow || i == languageRow || i == contactsSortRow) {
|
||||||
return 5;
|
return 5;
|
||||||
} else if (i == enableAnimationsRow || i == sendByEnterRow) {
|
} else if (i == enableAnimationsRow || i == sendByEnterRow) {
|
||||||
return 3;
|
return 3;
|
||||||
@ -1086,6 +1082,8 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
return 4;
|
return 4;
|
||||||
} else if (i == versionRow) {
|
} else if (i == versionRow) {
|
||||||
return 6;
|
return 6;
|
||||||
|
} else if (i == wifiDownloadRow || i == mobileDownloadRow || i == roamingDownloadRow) {
|
||||||
|
return 7;
|
||||||
} else {
|
} else {
|
||||||
return 2;
|
return 2;
|
||||||
}
|
}
|
||||||
@ -1093,7 +1091,7 @@ public class SettingsActivity extends BaseFragment implements NotificationCenter
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getViewTypeCount() {
|
public int getViewTypeCount() {
|
||||||
return 7;
|
return 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -21,31 +21,21 @@ import android.widget.TextView;
|
|||||||
|
|
||||||
import org.telegram.PhoneFormat.PhoneFormat;
|
import org.telegram.PhoneFormat.PhoneFormat;
|
||||||
import org.telegram.android.LocaleController;
|
import org.telegram.android.LocaleController;
|
||||||
import org.telegram.messenger.TLObject;
|
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.messenger.ConnectionsManager;
|
|
||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.RPCRequest;
|
|
||||||
import org.telegram.messenger.Utilities;
|
|
||||||
import org.telegram.ui.Adapters.BaseFragmentAdapter;
|
import org.telegram.ui.Adapters.BaseFragmentAdapter;
|
||||||
import org.telegram.ui.Cells.ChatOrUserCell;
|
import org.telegram.ui.Cells.ChatOrUserCell;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarMenu;
|
import org.telegram.ui.Views.ActionBar.ActionBarMenu;
|
||||||
import org.telegram.ui.Views.ActionBar.BaseFragment;
|
import org.telegram.ui.Views.ActionBar.BaseFragment;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.HashMap;
|
|
||||||
|
|
||||||
public class SettingsBlockedUsersActivity extends BaseFragment implements NotificationCenter.NotificationCenterDelegate, ContactsActivity.ContactsActivityDelegate {
|
public class SettingsBlockedUsersActivity extends BaseFragment implements NotificationCenter.NotificationCenterDelegate, ContactsActivity.ContactsActivityDelegate {
|
||||||
private ListView listView;
|
private ListView listView;
|
||||||
private ListAdapter listViewAdapter;
|
private ListAdapter listViewAdapter;
|
||||||
private boolean loading;
|
|
||||||
private View progressView;
|
private View progressView;
|
||||||
private TextView emptyView;
|
private TextView emptyView;
|
||||||
private ArrayList<TLRPC.TL_contactBlocked> blockedContacts = new ArrayList<TLRPC.TL_contactBlocked>();
|
|
||||||
private HashMap<Integer, TLRPC.TL_contactBlocked> blockedContactsDict = new HashMap<Integer, TLRPC.TL_contactBlocked>();
|
|
||||||
private int selectedUserId;
|
private int selectedUserId;
|
||||||
|
|
||||||
private final static int block_user = 1;
|
private final static int block_user = 1;
|
||||||
@ -53,15 +43,17 @@ public class SettingsBlockedUsersActivity extends BaseFragment implements Notifi
|
|||||||
@Override
|
@Override
|
||||||
public boolean onFragmentCreate() {
|
public boolean onFragmentCreate() {
|
||||||
super.onFragmentCreate();
|
super.onFragmentCreate();
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.updateInterfaces);
|
||||||
loadBlockedContacts(0, 200);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.blockedUsersDidLoaded);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onFragmentDestroy() {
|
public void onFragmentDestroy() {
|
||||||
super.onFragmentDestroy();
|
super.onFragmentDestroy();
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.updateInterfaces);
|
||||||
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.blockedUsersDidLoaded);
|
||||||
|
MessagesController.getInstance().getBlockedUsers(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -97,7 +89,7 @@ public class SettingsBlockedUsersActivity extends BaseFragment implements Notifi
|
|||||||
progressView = fragmentView.findViewById(R.id.progressLayout);
|
progressView = fragmentView.findViewById(R.id.progressLayout);
|
||||||
emptyView = (TextView)fragmentView.findViewById(R.id.searchEmptyView);
|
emptyView = (TextView)fragmentView.findViewById(R.id.searchEmptyView);
|
||||||
emptyView.setText(LocaleController.getString("NoBlocked", R.string.NoBlocked));
|
emptyView.setText(LocaleController.getString("NoBlocked", R.string.NoBlocked));
|
||||||
if (loading) {
|
if (MessagesController.getInstance().loadingBlockedUsers) {
|
||||||
progressView.setVisibility(View.VISIBLE);
|
progressView.setVisibility(View.VISIBLE);
|
||||||
emptyView.setVisibility(View.GONE);
|
emptyView.setVisibility(View.GONE);
|
||||||
listView.setEmptyView(null);
|
listView.setEmptyView(null);
|
||||||
@ -109,9 +101,9 @@ public class SettingsBlockedUsersActivity extends BaseFragment implements Notifi
|
|||||||
listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
|
listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
|
public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
|
||||||
if (i < blockedContacts.size()) {
|
if (i < MessagesController.getInstance().blockedUsers.size()) {
|
||||||
Bundle args = new Bundle();
|
Bundle args = new Bundle();
|
||||||
args.putInt("user_id", blockedContacts.get(i).user_id);
|
args.putInt("user_id", MessagesController.getInstance().blockedUsers.get(i));
|
||||||
presentFragment(new UserProfileActivity(args));
|
presentFragment(new UserProfileActivity(args));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -120,10 +112,10 @@ public class SettingsBlockedUsersActivity extends BaseFragment implements Notifi
|
|||||||
listView.setOnItemLongClickListener(new AdapterView.OnItemLongClickListener() {
|
listView.setOnItemLongClickListener(new AdapterView.OnItemLongClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public boolean onItemLongClick(AdapterView<?> adapterView, View view, int i, long l) {
|
public boolean onItemLongClick(AdapterView<?> adapterView, View view, int i, long l) {
|
||||||
if (i >= blockedContacts.size() || getParentActivity() == null) {
|
if (i < 0 || i >= MessagesController.getInstance().blockedUsers.size() || getParentActivity() == null) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
selectedUserId = blockedContacts.get(i).user_id;
|
selectedUserId = MessagesController.getInstance().blockedUsers.get(i);
|
||||||
|
|
||||||
AlertDialog.Builder builder = new AlertDialog.Builder(getParentActivity());
|
AlertDialog.Builder builder = new AlertDialog.Builder(getParentActivity());
|
||||||
|
|
||||||
@ -133,22 +125,7 @@ public class SettingsBlockedUsersActivity extends BaseFragment implements Notifi
|
|||||||
@Override
|
@Override
|
||||||
public void onClick(DialogInterface dialogInterface, int i) {
|
public void onClick(DialogInterface dialogInterface, int i) {
|
||||||
if (i == 0) {
|
if (i == 0) {
|
||||||
TLRPC.TL_contacts_unblock req = new TLRPC.TL_contacts_unblock();
|
MessagesController.getInstance().unblockUser(selectedUserId);
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(selectedUserId);
|
|
||||||
if (user == null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
req.id = MessagesController.getInputUser(user);
|
|
||||||
TLRPC.TL_contactBlocked blocked = blockedContactsDict.get(selectedUserId);
|
|
||||||
blockedContactsDict.remove(selectedUserId);
|
|
||||||
blockedContacts.remove(blocked);
|
|
||||||
listViewAdapter.notifyDataSetChanged();
|
|
||||||
ConnectionsManager.getInstance().performRpc(req, new RPCRequest.RPCRequestDelegate() {
|
|
||||||
@Override
|
|
||||||
public void run(TLObject response, TLRPC.TL_error error) {
|
|
||||||
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -166,71 +143,23 @@ public class SettingsBlockedUsersActivity extends BaseFragment implements Notifi
|
|||||||
return fragmentView;
|
return fragmentView;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void loadBlockedContacts(int offset, int count) {
|
|
||||||
if (loading) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
loading = true;
|
|
||||||
TLRPC.TL_contacts_getBlocked req = new TLRPC.TL_contacts_getBlocked();
|
|
||||||
req.offset = offset;
|
|
||||||
req.limit = count;
|
|
||||||
long requestId = ConnectionsManager.getInstance().performRpc(req, new RPCRequest.RPCRequestDelegate() {
|
|
||||||
@Override
|
|
||||||
public void run(TLObject response, TLRPC.TL_error error) {
|
|
||||||
if (error != null) {
|
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
loading = false;
|
|
||||||
if (progressView != null) {
|
|
||||||
progressView.setVisibility(View.GONE);
|
|
||||||
}
|
|
||||||
if (listView != null && listView.getEmptyView() == null) {
|
|
||||||
listView.setEmptyView(emptyView);
|
|
||||||
}
|
|
||||||
if (listViewAdapter != null) {
|
|
||||||
listViewAdapter.notifyDataSetChanged();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
final TLRPC.contacts_Blocked res = (TLRPC.contacts_Blocked)response;
|
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
loading = false;
|
|
||||||
for (TLRPC.User user : res.users) {
|
|
||||||
MessagesController.getInstance().users.put(user.id, user);
|
|
||||||
}
|
|
||||||
for (TLRPC.TL_contactBlocked blocked : res.blocked) {
|
|
||||||
if (!blockedContactsDict.containsKey(blocked.user_id)) {
|
|
||||||
blockedContacts.add(blocked);
|
|
||||||
blockedContactsDict.put(blocked.user_id, blocked);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (progressView != null) {
|
|
||||||
progressView.setVisibility(View.GONE);
|
|
||||||
}
|
|
||||||
if (listView != null && listView.getEmptyView() == null) {
|
|
||||||
listView.setEmptyView(emptyView);
|
|
||||||
}
|
|
||||||
if (listViewAdapter != null) {
|
|
||||||
listViewAdapter.notifyDataSetChanged();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
ConnectionsManager.getInstance().bindRequestToGuid(requestId, classGuid);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, Object... args) {
|
public void didReceivedNotification(int id, Object... args) {
|
||||||
if (id == MessagesController.updateInterfaces) {
|
if (id == NotificationCenter.updateInterfaces) {
|
||||||
int mask = (Integer)args[0];
|
int mask = (Integer)args[0];
|
||||||
if ((mask & MessagesController.UPDATE_MASK_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_NAME) != 0) {
|
if ((mask & MessagesController.UPDATE_MASK_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_NAME) != 0) {
|
||||||
updateVisibleRows(mask);
|
updateVisibleRows(mask);
|
||||||
}
|
}
|
||||||
|
} else if (id == NotificationCenter.blockedUsersDidLoaded) {
|
||||||
|
if (progressView != null) {
|
||||||
|
progressView.setVisibility(View.GONE);
|
||||||
|
}
|
||||||
|
if (listView != null && listView.getEmptyView() == null) {
|
||||||
|
listView.setEmptyView(emptyView);
|
||||||
|
}
|
||||||
|
if (listViewAdapter != null) {
|
||||||
|
listViewAdapter.notifyDataSetChanged();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -256,24 +185,11 @@ public class SettingsBlockedUsersActivity extends BaseFragment implements Notifi
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void didSelectContact(TLRPC.User user, String param) {
|
public void didSelectContact(final TLRPC.User user, String param) {
|
||||||
if (user == null || blockedContactsDict.containsKey(user.id)) {
|
if (user == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
TLRPC.TL_contacts_block req = new TLRPC.TL_contacts_block();
|
MessagesController.getInstance().blockUser(user.id);
|
||||||
req.id = MessagesController.getInputUser(user);
|
|
||||||
TLRPC.TL_contactBlocked blocked = new TLRPC.TL_contactBlocked();
|
|
||||||
blocked.user_id = user.id;
|
|
||||||
blocked.date = (int)(System.currentTimeMillis() / 1000);
|
|
||||||
blockedContactsDict.put(blocked.user_id, blocked);
|
|
||||||
blockedContacts.add(blocked);
|
|
||||||
listViewAdapter.notifyDataSetChanged();
|
|
||||||
ConnectionsManager.getInstance().performRpc(req, new RPCRequest.RPCRequestDelegate() {
|
|
||||||
@Override
|
|
||||||
public void run(TLObject response, TLRPC.TL_error error) {
|
|
||||||
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private class ListAdapter extends BaseFragmentAdapter {
|
private class ListAdapter extends BaseFragmentAdapter {
|
||||||
@ -290,15 +206,15 @@ public class SettingsBlockedUsersActivity extends BaseFragment implements Notifi
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isEnabled(int i) {
|
public boolean isEnabled(int i) {
|
||||||
return i != blockedContacts.size();
|
return i != MessagesController.getInstance().blockedUsers.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getCount() {
|
public int getCount() {
|
||||||
if (blockedContacts.isEmpty()) {
|
if (MessagesController.getInstance().blockedUsers.isEmpty()) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
return blockedContacts.size() + 1;
|
return MessagesController.getInstance().blockedUsers.size() + 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -325,7 +241,7 @@ public class SettingsBlockedUsersActivity extends BaseFragment implements Notifi
|
|||||||
((ChatOrUserCell)view).usePadding = false;
|
((ChatOrUserCell)view).usePadding = false;
|
||||||
((ChatOrUserCell)view).useSeparator = true;
|
((ChatOrUserCell)view).useSeparator = true;
|
||||||
}
|
}
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(blockedContacts.get(i).user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(MessagesController.getInstance().blockedUsers.get(i));
|
||||||
((ChatOrUserCell)view).setData(user, null, null, null, user.phone != null && user.phone.length() != 0 ? PhoneFormat.getInstance().format("+" + user.phone) : "Unknown");
|
((ChatOrUserCell)view).setData(user, null, null, null, user.phone != null && user.phone.length() != 0 ? PhoneFormat.getInstance().format("+" + user.phone) : "Unknown");
|
||||||
} else if (type == 1) {
|
} else if (type == 1) {
|
||||||
if (view == null) {
|
if (view == null) {
|
||||||
@ -340,7 +256,7 @@ public class SettingsBlockedUsersActivity extends BaseFragment implements Notifi
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getItemViewType(int i) {
|
public int getItemViewType(int i) {
|
||||||
if(i == blockedContacts.size()) {
|
if(i == MessagesController.getInstance().blockedUsers.size()) {
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
@ -353,7 +269,7 @@ public class SettingsBlockedUsersActivity extends BaseFragment implements Notifi
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isEmpty() {
|
public boolean isEmpty() {
|
||||||
return blockedContacts.isEmpty();
|
return MessagesController.getInstance().blockedUsers.isEmpty();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -25,7 +25,7 @@ import org.telegram.messenger.TLObject;
|
|||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.messenger.ConnectionsManager;
|
import org.telegram.messenger.ConnectionsManager;
|
||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.RPCRequest;
|
import org.telegram.messenger.RPCRequest;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
@ -65,7 +65,7 @@ public class SettingsChangeNameActivity extends BaseFragment {
|
|||||||
|
|
||||||
fragmentView = inflater.inflate(R.layout.settings_change_name_layout, container, false);
|
fragmentView = inflater.inflate(R.layout.settings_change_name_layout, container, false);
|
||||||
|
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(UserConfig.getClientUserId());
|
TLRPC.User user = MessagesController.getInstance().getUser(UserConfig.getClientUserId());
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
user = UserConfig.getCurrentUser();
|
user = UserConfig.getCurrentUser();
|
||||||
}
|
}
|
||||||
@ -131,13 +131,13 @@ public class SettingsChangeNameActivity extends BaseFragment {
|
|||||||
}
|
}
|
||||||
UserConfig.getCurrentUser().first_name = req.first_name = firstNameField.getText().toString();
|
UserConfig.getCurrentUser().first_name = req.first_name = firstNameField.getText().toString();
|
||||||
UserConfig.getCurrentUser().last_name = req.last_name = lastNameField.getText().toString();
|
UserConfig.getCurrentUser().last_name = req.last_name = lastNameField.getText().toString();
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(UserConfig.getClientUserId());
|
TLRPC.User user = MessagesController.getInstance().getUser(UserConfig.getClientUserId());
|
||||||
if (user != null) {
|
if (user != null) {
|
||||||
user.first_name = req.first_name;
|
user.first_name = req.first_name;
|
||||||
user.last_name = req.last_name;
|
user.last_name = req.last_name;
|
||||||
}
|
}
|
||||||
UserConfig.saveConfig(true);
|
UserConfig.saveConfig(true);
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.updateInterfaces, MessagesController.UPDATE_MASK_NAME);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.updateInterfaces, MessagesController.UPDATE_MASK_NAME);
|
||||||
ConnectionsManager.getInstance().performRpc(req, new RPCRequest.RPCRequestDelegate() {
|
ConnectionsManager.getInstance().performRpc(req, new RPCRequest.RPCRequestDelegate() {
|
||||||
@Override
|
@Override
|
||||||
public void run(TLObject response, TLRPC.TL_error error) {
|
public void run(TLObject response, TLRPC.TL_error error) {
|
||||||
|
@ -27,9 +27,10 @@ import android.widget.ListView;
|
|||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
import android.widget.Toast;
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
import org.telegram.android.AndroidUtilities;
|
||||||
import org.telegram.android.LocaleController;
|
import org.telegram.android.LocaleController;
|
||||||
import org.telegram.android.NotificationsController;
|
import org.telegram.android.NotificationsController;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.TLObject;
|
import org.telegram.messenger.TLObject;
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.messenger.ConnectionsManager;
|
import org.telegram.messenger.ConnectionsManager;
|
||||||
@ -37,7 +38,6 @@ import org.telegram.messenger.FileLog;
|
|||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.RPCRequest;
|
import org.telegram.messenger.RPCRequest;
|
||||||
import org.telegram.messenger.Utilities;
|
|
||||||
import org.telegram.ui.Adapters.BaseFragmentAdapter;
|
import org.telegram.ui.Adapters.BaseFragmentAdapter;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
||||||
import org.telegram.ui.Views.ActionBar.BaseFragment;
|
import org.telegram.ui.Views.ActionBar.BaseFragment;
|
||||||
@ -104,7 +104,7 @@ public class SettingsNotificationsActivity extends BaseFragment implements Notif
|
|||||||
resetSectionRow = rowCount++;
|
resetSectionRow = rowCount++;
|
||||||
resetNotificationsRow = rowCount++;
|
resetNotificationsRow = rowCount++;
|
||||||
|
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.notificationsSettingsUpdated);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.notificationsSettingsUpdated);
|
||||||
|
|
||||||
return super.onFragmentCreate();
|
return super.onFragmentCreate();
|
||||||
}
|
}
|
||||||
@ -112,7 +112,7 @@ public class SettingsNotificationsActivity extends BaseFragment implements Notif
|
|||||||
@Override
|
@Override
|
||||||
public void onFragmentDestroy() {
|
public void onFragmentDestroy() {
|
||||||
super.onFragmentDestroy();
|
super.onFragmentDestroy();
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.notificationsSettingsUpdated);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.notificationsSettingsUpdated);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -165,19 +165,6 @@ public class SettingsNotificationsActivity extends BaseFragment implements Notif
|
|||||||
editor.commit();
|
editor.commit();
|
||||||
listView.invalidateViews();
|
listView.invalidateViews();
|
||||||
updateServerNotificationsSettings(i == groupPreviewRow);
|
updateServerNotificationsSettings(i == groupPreviewRow);
|
||||||
} else if (i == messageVibrateRow || i == groupVibrateRow) {
|
|
||||||
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("Notifications", Activity.MODE_PRIVATE);
|
|
||||||
SharedPreferences.Editor editor = preferences.edit();
|
|
||||||
boolean enabled;
|
|
||||||
if (i == messageVibrateRow) {
|
|
||||||
enabled = preferences.getBoolean("EnableVibrateAll", true);
|
|
||||||
editor.putBoolean("EnableVibrateAll", !enabled);
|
|
||||||
} else if (i == groupVibrateRow) {
|
|
||||||
enabled = preferences.getBoolean("EnableVibrateGroup", true);
|
|
||||||
editor.putBoolean("EnableVibrateGroup", !enabled);
|
|
||||||
}
|
|
||||||
editor.commit();
|
|
||||||
listView.invalidateViews();
|
|
||||||
} else if (i == messageSoundRow || i == groupSoundRow) {
|
} else if (i == messageSoundRow || i == groupSoundRow) {
|
||||||
try {
|
try {
|
||||||
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("Notifications", Activity.MODE_PRIVATE);
|
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("Notifications", Activity.MODE_PRIVATE);
|
||||||
@ -226,7 +213,7 @@ public class SettingsNotificationsActivity extends BaseFragment implements Notif
|
|||||||
ConnectionsManager.getInstance().performRpc(req, new RPCRequest.RPCRequestDelegate() {
|
ConnectionsManager.getInstance().performRpc(req, new RPCRequest.RPCRequestDelegate() {
|
||||||
@Override
|
@Override
|
||||||
public void run(TLObject response, TLRPC.TL_error error) {
|
public void run(TLObject response, TLRPC.TL_error error) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
MessagesController.getInstance().enableJoined = true;
|
MessagesController.getInstance().enableJoined = true;
|
||||||
@ -393,6 +380,40 @@ public class SettingsNotificationsActivity extends BaseFragment implements Notif
|
|||||||
});
|
});
|
||||||
builder.setNegativeButton(LocaleController.getString("Cancel", R.string.Cancel), null);
|
builder.setNegativeButton(LocaleController.getString("Cancel", R.string.Cancel), null);
|
||||||
showAlertDialog(builder);
|
showAlertDialog(builder);
|
||||||
|
} else if (i == messageVibrateRow || i == groupVibrateRow) {
|
||||||
|
AlertDialog.Builder builder = new AlertDialog.Builder(getParentActivity());
|
||||||
|
builder.setTitle(LocaleController.getString("Vibrate", R.string.Vibrate));
|
||||||
|
builder.setItems(new CharSequence[] {
|
||||||
|
LocaleController.getString("Disabled", R.string.Disabled),
|
||||||
|
LocaleController.getString("Default", R.string.Default),
|
||||||
|
LocaleController.getString("Short", R.string.Short),
|
||||||
|
LocaleController.getString("Long", R.string.Long)
|
||||||
|
}, new DialogInterface.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
|
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("Notifications", Activity.MODE_PRIVATE);
|
||||||
|
SharedPreferences.Editor editor = preferences.edit();
|
||||||
|
String param = "vibrate_messages";
|
||||||
|
if (i == groupVibrateRow) {
|
||||||
|
param = "vibrate_group";
|
||||||
|
}
|
||||||
|
if (which == 0) {
|
||||||
|
editor.putInt(param, 2);
|
||||||
|
} else if (which == 1) {
|
||||||
|
editor.putInt(param, 0);
|
||||||
|
} else if (which == 2) {
|
||||||
|
editor.putInt(param, 1);
|
||||||
|
} else if (which == 3) {
|
||||||
|
editor.putInt(param, 3);
|
||||||
|
}
|
||||||
|
editor.commit();
|
||||||
|
if (listView != null) {
|
||||||
|
listView.invalidateViews();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
builder.setNegativeButton(LocaleController.getString("Cancel", R.string.Cancel), null);
|
||||||
|
showAlertDialog(builder);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -473,7 +494,7 @@ public class SettingsNotificationsActivity extends BaseFragment implements Notif
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, Object... args) {
|
public void didReceivedNotification(int id, Object... args) {
|
||||||
if (id == MessagesController.notificationsSettingsUpdated) {
|
if (id == NotificationCenter.notificationsSettingsUpdated) {
|
||||||
listView.invalidateViews();
|
listView.invalidateViews();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -567,14 +588,6 @@ public class SettingsNotificationsActivity extends BaseFragment implements Notif
|
|||||||
}
|
}
|
||||||
textView.setText(LocaleController.getString("MessagePreview", R.string.MessagePreview));
|
textView.setText(LocaleController.getString("MessagePreview", R.string.MessagePreview));
|
||||||
divider.setVisibility(View.VISIBLE);
|
divider.setVisibility(View.VISIBLE);
|
||||||
} else if (i == messageVibrateRow || i == groupVibrateRow) {
|
|
||||||
if (i == messageVibrateRow) {
|
|
||||||
enabled = preferences.getBoolean("EnableVibrateAll", true);
|
|
||||||
} else if (i == groupVibrateRow) {
|
|
||||||
enabled = preferences.getBoolean("EnableVibrateGroup", true);
|
|
||||||
}
|
|
||||||
textView.setText(LocaleController.getString("Vibrate", R.string.Vibrate));
|
|
||||||
divider.setVisibility(View.VISIBLE);
|
|
||||||
} else if (i == inappSoundRow) {
|
} else if (i == inappSoundRow) {
|
||||||
enabled = preferences.getBoolean("EnableInAppSounds", true);
|
enabled = preferences.getBoolean("EnableInAppSounds", true);
|
||||||
textView.setText(LocaleController.getString("InAppSounds", R.string.InAppSounds));
|
textView.setText(LocaleController.getString("InAppSounds", R.string.InAppSounds));
|
||||||
@ -674,6 +687,33 @@ public class SettingsNotificationsActivity extends BaseFragment implements Notif
|
|||||||
colorView.setBackgroundColor(preferences.getInt("GroupLed", 0xff00ff00));
|
colorView.setBackgroundColor(preferences.getInt("GroupLed", 0xff00ff00));
|
||||||
}
|
}
|
||||||
divider.setVisibility(View.VISIBLE);
|
divider.setVisibility(View.VISIBLE);
|
||||||
|
} else if (type == 4) {
|
||||||
|
if (view == null) {
|
||||||
|
LayoutInflater li = (LayoutInflater)mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
|
||||||
|
view = li.inflate(R.layout.user_profile_leftright_row_layout, viewGroup, false);
|
||||||
|
}
|
||||||
|
TextView textView = (TextView)view.findViewById(R.id.settings_row_text);
|
||||||
|
TextView detailTextView = (TextView)view.findViewById(R.id.settings_row_text_detail);
|
||||||
|
|
||||||
|
View divider = view.findViewById(R.id.settings_row_divider);
|
||||||
|
SharedPreferences preferences = mContext.getSharedPreferences("Notifications", Activity.MODE_PRIVATE);
|
||||||
|
int value = 0;
|
||||||
|
textView.setText(LocaleController.getString("Vibrate", R.string.Vibrate));
|
||||||
|
divider.setVisibility(View.VISIBLE);
|
||||||
|
if (i == messageVibrateRow) {
|
||||||
|
value = preferences.getInt("vibrate_messages", 0);
|
||||||
|
} else if (i == groupVibrateRow) {
|
||||||
|
value = preferences.getInt("vibrate_group", 0);
|
||||||
|
}
|
||||||
|
if (value == 0) {
|
||||||
|
detailTextView.setText(LocaleController.getString("Default", R.string.Default));
|
||||||
|
} else if (value == 1) {
|
||||||
|
detailTextView.setText(LocaleController.getString("Short", R.string.Short));
|
||||||
|
} else if (value == 2) {
|
||||||
|
detailTextView.setText(LocaleController.getString("Disabled", R.string.Disabled));
|
||||||
|
} else if (value == 3) {
|
||||||
|
detailTextView.setText(LocaleController.getString("Long", R.string.Long));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return view;
|
return view;
|
||||||
}
|
}
|
||||||
@ -682,14 +722,16 @@ public class SettingsNotificationsActivity extends BaseFragment implements Notif
|
|||||||
public int getItemViewType(int i) {
|
public int getItemViewType(int i) {
|
||||||
if (i == messageSectionRow || i == groupSectionRow || i == inappSectionRow || i == eventsSectionRow || i == otherSectionRow || i == resetSectionRow) {
|
if (i == messageSectionRow || i == groupSectionRow || i == inappSectionRow || i == eventsSectionRow || i == otherSectionRow || i == resetSectionRow) {
|
||||||
return 0;
|
return 0;
|
||||||
} else if (i == messageAlertRow || i == messagePreviewRow || i == messageVibrateRow ||
|
} else if (i == messageAlertRow || i == messagePreviewRow ||
|
||||||
i == groupAlertRow || i == groupPreviewRow || i == groupVibrateRow ||
|
i == groupAlertRow || i == groupPreviewRow ||
|
||||||
i == inappSoundRow || i == inappVibrateRow || i == inappPreviewRow ||
|
i == inappSoundRow || i == inappVibrateRow || i == inappPreviewRow ||
|
||||||
i == contactJoinedRow ||
|
i == contactJoinedRow ||
|
||||||
i == pebbleAlertRow || i == notificationsServiceRow || i == badgeNumberRow) {
|
i == pebbleAlertRow || i == notificationsServiceRow || i == badgeNumberRow) {
|
||||||
return 1;
|
return 1;
|
||||||
} else if (i == messageLedRow || i == groupLedRow) {
|
} else if (i == messageLedRow || i == groupLedRow) {
|
||||||
return 3;
|
return 3;
|
||||||
|
} else if (i == groupVibrateRow || i == messageVibrateRow) {
|
||||||
|
return 4;
|
||||||
} else {
|
} else {
|
||||||
return 2;
|
return 2;
|
||||||
}
|
}
|
||||||
@ -697,7 +739,7 @@ public class SettingsNotificationsActivity extends BaseFragment implements Notif
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getViewTypeCount() {
|
public int getViewTypeCount() {
|
||||||
return 4;
|
return 5;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -30,6 +30,7 @@ import android.widget.ProgressBar;
|
|||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
import org.telegram.android.AndroidUtilities;
|
import org.telegram.android.AndroidUtilities;
|
||||||
|
import org.telegram.android.ImageLoader;
|
||||||
import org.telegram.android.LocaleController;
|
import org.telegram.android.LocaleController;
|
||||||
import org.telegram.messenger.TLObject;
|
import org.telegram.messenger.TLObject;
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
@ -37,11 +38,11 @@ import org.telegram.messenger.ConnectionsManager;
|
|||||||
import org.telegram.messenger.FileLoader;
|
import org.telegram.messenger.FileLoader;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.android.MessagesStorage;
|
import org.telegram.android.MessagesStorage;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.RPCRequest;
|
import org.telegram.messenger.RPCRequest;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.objects.PhotoObject;
|
import org.telegram.android.PhotoObject;
|
||||||
import org.telegram.ui.Adapters.BaseFragmentAdapter;
|
import org.telegram.ui.Adapters.BaseFragmentAdapter;
|
||||||
import org.telegram.ui.Views.BackupImageView;
|
import org.telegram.ui.Views.BackupImageView;
|
||||||
import org.telegram.ui.Views.ActionBar.BaseFragment;
|
import org.telegram.ui.Views.ActionBar.BaseFragment;
|
||||||
@ -71,10 +72,10 @@ public class SettingsWallpapersActivity extends BaseFragment implements Notifica
|
|||||||
public boolean onFragmentCreate() {
|
public boolean onFragmentCreate() {
|
||||||
super.onFragmentCreate();
|
super.onFragmentCreate();
|
||||||
|
|
||||||
NotificationCenter.getInstance().addObserver(this, FileLoader.FileDidFailedLoad);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.FileDidFailedLoad);
|
||||||
NotificationCenter.getInstance().addObserver(this, FileLoader.FileDidLoaded);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.FileDidLoaded);
|
||||||
NotificationCenter.getInstance().addObserver(this, FileLoader.FileLoadProgressChanged);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.FileLoadProgressChanged);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesStorage.wallpapersDidLoaded);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.wallpapersDidLoaded);
|
||||||
|
|
||||||
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("mainconfig", Activity.MODE_PRIVATE);
|
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("mainconfig", Activity.MODE_PRIVATE);
|
||||||
selectedBackground = preferences.getInt("selectedBackground", 1000001);
|
selectedBackground = preferences.getInt("selectedBackground", 1000001);
|
||||||
@ -88,10 +89,10 @@ public class SettingsWallpapersActivity extends BaseFragment implements Notifica
|
|||||||
@Override
|
@Override
|
||||||
public void onFragmentDestroy() {
|
public void onFragmentDestroy() {
|
||||||
super.onFragmentDestroy();
|
super.onFragmentDestroy();
|
||||||
NotificationCenter.getInstance().removeObserver(this, FileLoader.FileDidFailedLoad);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.FileDidFailedLoad);
|
||||||
NotificationCenter.getInstance().removeObserver(this, FileLoader.FileDidLoaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.FileDidLoaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, FileLoader.FileLoadProgressChanged);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.FileLoadProgressChanged);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesStorage.wallpapersDidLoaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.wallpapersDidLoaded);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -217,7 +218,7 @@ public class SettingsWallpapersActivity extends BaseFragment implements Notifica
|
|||||||
if (requestCode == 10) {
|
if (requestCode == 10) {
|
||||||
Utilities.addMediaToGallery(currentPicturePath);
|
Utilities.addMediaToGallery(currentPicturePath);
|
||||||
try {
|
try {
|
||||||
Bitmap bitmap = FileLoader.loadBitmap(currentPicturePath, null, AndroidUtilities.dp(320), AndroidUtilities.dp(480));
|
Bitmap bitmap = ImageLoader.loadBitmap(currentPicturePath, null, AndroidUtilities.dp(320), AndroidUtilities.dp(480));
|
||||||
File toFile = new File(ApplicationLoader.applicationContext.getFilesDir(), "wallpaper-temp.jpg");
|
File toFile = new File(ApplicationLoader.applicationContext.getFilesDir(), "wallpaper-temp.jpg");
|
||||||
FileOutputStream stream = new FileOutputStream(toFile);
|
FileOutputStream stream = new FileOutputStream(toFile);
|
||||||
bitmap.compress(Bitmap.CompressFormat.JPEG, 87, stream);
|
bitmap.compress(Bitmap.CompressFormat.JPEG, 87, stream);
|
||||||
@ -233,7 +234,7 @@ public class SettingsWallpapersActivity extends BaseFragment implements Notifica
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
Bitmap bitmap = FileLoader.loadBitmap(null, data.getData(), AndroidUtilities.dp(320), AndroidUtilities.dp(480));
|
Bitmap bitmap = ImageLoader.loadBitmap(null, data.getData(), AndroidUtilities.dp(320), AndroidUtilities.dp(480));
|
||||||
File toFile = new File(ApplicationLoader.applicationContext.getFilesDir(), "wallpaper-temp.jpg");
|
File toFile = new File(ApplicationLoader.applicationContext.getFilesDir(), "wallpaper-temp.jpg");
|
||||||
FileOutputStream stream = new FileOutputStream(toFile);
|
FileOutputStream stream = new FileOutputStream(toFile);
|
||||||
bitmap.compress(Bitmap.CompressFormat.JPEG, 87, stream);
|
bitmap.compress(Bitmap.CompressFormat.JPEG, 87, stream);
|
||||||
@ -280,11 +281,11 @@ public class SettingsWallpapersActivity extends BaseFragment implements Notifica
|
|||||||
progressBar.setVisibility(View.VISIBLE);
|
progressBar.setVisibility(View.VISIBLE);
|
||||||
loadingSize = size;
|
loadingSize = size;
|
||||||
selectedColor = 0;
|
selectedColor = 0;
|
||||||
FileLoader.getInstance().loadFile(null, size, null, null);
|
FileLoader.getInstance().loadFile(size);
|
||||||
backgroundImage.setBackgroundColor(0);
|
backgroundImage.setBackgroundColor(0);
|
||||||
} else {
|
} else {
|
||||||
if (loadingFile != null) {
|
if (loadingFile != null) {
|
||||||
FileLoader.getInstance().cancelLoadFile(null, loadingSize, null, null);
|
FileLoader.getInstance().cancelLoadFile(loadingSize);
|
||||||
}
|
}
|
||||||
loadingFileObject = null;
|
loadingFileObject = null;
|
||||||
loadingFile = null;
|
loadingFile = null;
|
||||||
@ -297,7 +298,7 @@ public class SettingsWallpapersActivity extends BaseFragment implements Notifica
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (loadingFile != null) {
|
if (loadingFile != null) {
|
||||||
FileLoader.getInstance().cancelLoadFile(null, loadingSize, null, null);
|
FileLoader.getInstance().cancelLoadFile(loadingSize);
|
||||||
}
|
}
|
||||||
if (selectedBackground == 1000001) {
|
if (selectedBackground == 1000001) {
|
||||||
backgroundImage.setImageResource(R.drawable.background_hd);
|
backgroundImage.setImageResource(R.drawable.background_hd);
|
||||||
@ -335,7 +336,7 @@ public class SettingsWallpapersActivity extends BaseFragment implements Notifica
|
|||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, final Object... args) {
|
public void didReceivedNotification(int id, final Object... args) {
|
||||||
if (id == FileLoader.FileDidFailedLoad) {
|
if (id == NotificationCenter.FileDidFailedLoad) {
|
||||||
String location = (String)args[0];
|
String location = (String)args[0];
|
||||||
if (loadingFile != null && loadingFile.equals(location)) {
|
if (loadingFile != null && loadingFile.equals(location)) {
|
||||||
loadingFileObject = null;
|
loadingFileObject = null;
|
||||||
@ -344,7 +345,7 @@ public class SettingsWallpapersActivity extends BaseFragment implements Notifica
|
|||||||
progressBar.setVisibility(View.GONE);
|
progressBar.setVisibility(View.GONE);
|
||||||
doneButton.setEnabled(false);
|
doneButton.setEnabled(false);
|
||||||
}
|
}
|
||||||
} else if (id == FileLoader.FileDidLoaded) {
|
} else if (id == NotificationCenter.FileDidLoaded) {
|
||||||
String location = (String)args[0];
|
String location = (String)args[0];
|
||||||
if (loadingFile != null && loadingFile.equals(location)) {
|
if (loadingFile != null && loadingFile.equals(location)) {
|
||||||
backgroundImage.setImageURI(Uri.fromFile(loadingFileObject));
|
backgroundImage.setImageURI(Uri.fromFile(loadingFileObject));
|
||||||
@ -355,14 +356,14 @@ public class SettingsWallpapersActivity extends BaseFragment implements Notifica
|
|||||||
loadingFile = null;
|
loadingFile = null;
|
||||||
loadingSize = null;
|
loadingSize = null;
|
||||||
}
|
}
|
||||||
} else if (id == FileLoader.FileLoadProgressChanged) {
|
} else if (id == NotificationCenter.FileLoadProgressChanged) {
|
||||||
String location = (String)args[0];
|
String location = (String)args[0];
|
||||||
if (loadingFile != null && loadingFile.equals(location)) {
|
if (loadingFile != null && loadingFile.equals(location)) {
|
||||||
Float progress = (Float)args[1];
|
Float progress = (Float)args[1];
|
||||||
progressBar.setProgress((int)(progress * 100));
|
progressBar.setProgress((int)(progress * 100));
|
||||||
}
|
}
|
||||||
} else if (id == MessagesStorage.wallpapersDidLoaded) {
|
} else if (id == NotificationCenter.wallpapersDidLoaded) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
wallPapers = (ArrayList<TLRPC.WallPaper>)args[0];
|
wallPapers = (ArrayList<TLRPC.WallPaper>)args[0];
|
||||||
@ -396,7 +397,7 @@ public class SettingsWallpapersActivity extends BaseFragment implements Notifica
|
|||||||
if (error != null) {
|
if (error != null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
wallPapers.clear();
|
wallPapers.clear();
|
||||||
|
@ -26,18 +26,16 @@ import android.widget.TextView;
|
|||||||
import org.telegram.android.AndroidUtilities;
|
import org.telegram.android.AndroidUtilities;
|
||||||
import org.telegram.PhoneFormat.PhoneFormat;
|
import org.telegram.PhoneFormat.PhoneFormat;
|
||||||
import org.telegram.android.LocaleController;
|
import org.telegram.android.LocaleController;
|
||||||
import org.telegram.messenger.TLObject;
|
import org.telegram.android.SendMessagesHelper;
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.messenger.ConnectionsManager;
|
|
||||||
import org.telegram.android.ContactsController;
|
import org.telegram.android.ContactsController;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
import org.telegram.android.MessagesStorage;
|
import org.telegram.android.MessagesStorage;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.RPCRequest;
|
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.objects.MessageObject;
|
import org.telegram.android.MessageObject;
|
||||||
import org.telegram.ui.Adapters.BaseFragmentAdapter;
|
import org.telegram.ui.Adapters.BaseFragmentAdapter;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
import org.telegram.ui.Views.ActionBar.ActionBarLayer;
|
||||||
import org.telegram.ui.Views.ActionBar.ActionBarMenu;
|
import org.telegram.ui.Views.ActionBar.ActionBarMenu;
|
||||||
@ -56,6 +54,7 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
private boolean creatingChat = false;
|
private boolean creatingChat = false;
|
||||||
private long dialog_id;
|
private long dialog_id;
|
||||||
private TLRPC.EncryptedChat currentEncryptedChat;
|
private TLRPC.EncryptedChat currentEncryptedChat;
|
||||||
|
private boolean userBlocked = false;
|
||||||
|
|
||||||
private final static int add_contact = 1;
|
private final static int add_contact = 1;
|
||||||
private final static int block_contact = 2;
|
private final static int block_contact = 2;
|
||||||
@ -80,28 +79,34 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onFragmentCreate() {
|
public boolean onFragmentCreate() {
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.updateInterfaces);
|
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.contactsDidLoaded);
|
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.mediaCountDidLoaded);
|
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.encryptedChatCreated);
|
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.encryptedChatUpdated);
|
|
||||||
user_id = arguments.getInt("user_id", 0);
|
user_id = arguments.getInt("user_id", 0);
|
||||||
dialog_id = arguments.getLong("dialog_id", 0);
|
dialog_id = arguments.getLong("dialog_id", 0);
|
||||||
if (dialog_id != 0) {
|
if (dialog_id != 0) {
|
||||||
currentEncryptedChat = MessagesController.getInstance().encryptedChats.get((int)(dialog_id >> 32));
|
currentEncryptedChat = MessagesController.getInstance().getEncryptedChat((int)(dialog_id >> 32));
|
||||||
}
|
}
|
||||||
updateRowsIds();
|
updateRowsIds();
|
||||||
return MessagesController.getInstance().users.get(user_id) != null && super.onFragmentCreate();
|
if (MessagesController.getInstance().getUser(user_id) == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.updateInterfaces);
|
||||||
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.contactsDidLoaded);
|
||||||
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.mediaCountDidLoaded);
|
||||||
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.encryptedChatCreated);
|
||||||
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.encryptedChatUpdated);
|
||||||
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.blockedUsersDidLoaded);
|
||||||
|
userBlocked = MessagesController.getInstance().blockedUsers.contains(user_id);
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onFragmentDestroy() {
|
public void onFragmentDestroy() {
|
||||||
super.onFragmentDestroy();
|
super.onFragmentDestroy();
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.updateInterfaces);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.updateInterfaces);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.contactsDidLoaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.contactsDidLoaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.mediaCountDidLoaded);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.mediaCountDidLoaded);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.encryptedChatCreated);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.encryptedChatCreated);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.encryptedChatUpdated);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.encryptedChatUpdated);
|
||||||
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.blockedUsersDidLoaded);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateRowsIds() {
|
private void updateRowsIds() {
|
||||||
@ -135,37 +140,31 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
}
|
}
|
||||||
actionBarLayer.setActionBarMenuOnItemClick(new ActionBarLayer.ActionBarMenuOnItemClick() {
|
actionBarLayer.setActionBarMenuOnItemClick(new ActionBarLayer.ActionBarMenuOnItemClick() {
|
||||||
@Override
|
@Override
|
||||||
public void onItemClick(int id) {
|
public void onItemClick(final int id) {
|
||||||
if (id == -1) {
|
if (id == -1) {
|
||||||
finishFragment();
|
finishFragment();
|
||||||
} else if (id == block_contact) {
|
} else if (id == block_contact) {
|
||||||
AlertDialog.Builder builder = new AlertDialog.Builder(getParentActivity());
|
AlertDialog.Builder builder = new AlertDialog.Builder(getParentActivity());
|
||||||
|
if (!userBlocked) {
|
||||||
builder.setMessage(LocaleController.getString("AreYouSureBlockContact", R.string.AreYouSureBlockContact));
|
builder.setMessage(LocaleController.getString("AreYouSureBlockContact", R.string.AreYouSureBlockContact));
|
||||||
|
} else {
|
||||||
|
builder.setMessage(LocaleController.getString("AreYouSureUnblockContact", R.string.AreYouSureUnblockContact));
|
||||||
|
}
|
||||||
builder.setTitle(LocaleController.getString("AppName", R.string.AppName));
|
builder.setTitle(LocaleController.getString("AppName", R.string.AppName));
|
||||||
builder.setPositiveButton(LocaleController.getString("OK", R.string.OK), new DialogInterface.OnClickListener() {
|
builder.setPositiveButton(LocaleController.getString("OK", R.string.OK), new DialogInterface.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(DialogInterface dialogInterface, int i) {
|
public void onClick(DialogInterface dialogInterface, int i) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(user_id);
|
if (!userBlocked) {
|
||||||
if (user == null) {
|
MessagesController.getInstance().blockUser(user_id);
|
||||||
return;
|
} else {
|
||||||
|
MessagesController.getInstance().unblockUser(user_id);
|
||||||
}
|
}
|
||||||
TLRPC.TL_contacts_block req = new TLRPC.TL_contacts_block();
|
|
||||||
req.id = MessagesController.getInputUser(user);
|
|
||||||
TLRPC.TL_contactBlocked blocked = new TLRPC.TL_contactBlocked();
|
|
||||||
blocked.user_id = user_id;
|
|
||||||
blocked.date = (int)(System.currentTimeMillis() / 1000);
|
|
||||||
ConnectionsManager.getInstance().performRpc(req, new RPCRequest.RPCRequestDelegate() {
|
|
||||||
@Override
|
|
||||||
public void run(TLObject response, TLRPC.TL_error error) {
|
|
||||||
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
builder.setNegativeButton(LocaleController.getString("Cancel", R.string.Cancel), null);
|
builder.setNegativeButton(LocaleController.getString("Cancel", R.string.Cancel), null);
|
||||||
showAlertDialog(builder);
|
showAlertDialog(builder);
|
||||||
} else if (id == add_contact) {
|
} else if (id == add_contact) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(user_id);
|
||||||
Bundle args = new Bundle();
|
Bundle args = new Bundle();
|
||||||
args.putInt("user_id", user.id);
|
args.putInt("user_id", user.id);
|
||||||
presentFragment(new ContactAddActivity(args));
|
presentFragment(new ContactAddActivity(args));
|
||||||
@ -181,7 +180,7 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
args.putInt("user_id", user_id);
|
args.putInt("user_id", user_id);
|
||||||
presentFragment(new ContactAddActivity(args));
|
presentFragment(new ContactAddActivity(args));
|
||||||
} else if (id == delete_contact) {
|
} else if (id == delete_contact) {
|
||||||
final TLRPC.User user = MessagesController.getInstance().users.get(user_id);
|
final TLRPC.User user = MessagesController.getInstance().getUser(user_id);
|
||||||
if (user == null || getParentActivity() == null) {
|
if (user == null || getParentActivity() == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -224,7 +223,7 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
@Override
|
@Override
|
||||||
public void onClick(DialogInterface dialogInterface, int i) {
|
public void onClick(DialogInterface dialogInterface, int i) {
|
||||||
creatingChat = true;
|
creatingChat = true;
|
||||||
MessagesController.getInstance().startSecretChat(getParentActivity(), MessagesController.getInstance().users.get(user_id));
|
MessagesController.getInstance().startSecretChat(getParentActivity(), MessagesController.getInstance().getUser(user_id));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
builder.setNegativeButton(LocaleController.getString("Cancel", R.string.Cancel), null);
|
builder.setNegativeButton(LocaleController.getString("Cancel", R.string.Cancel), null);
|
||||||
@ -292,7 +291,7 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
if (listView != null) {
|
if (listView != null) {
|
||||||
listView.invalidateViews();
|
listView.invalidateViews();
|
||||||
}
|
}
|
||||||
MessagesController.getInstance().sendTTLMessage(currentEncryptedChat);
|
SendMessagesHelper.getInstance().sendTTLMessage(currentEncryptedChat);
|
||||||
MessagesStorage.getInstance().updateEncryptedChat(currentEncryptedChat);
|
MessagesStorage.getInstance().updateEncryptedChat(currentEncryptedChat);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -321,16 +320,16 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void didReceivedNotification(int id, Object... args) {
|
public void didReceivedNotification(int id, Object... args) {
|
||||||
if (id == MessagesController.updateInterfaces) {
|
if (id == NotificationCenter.updateInterfaces) {
|
||||||
int mask = (Integer)args[0];
|
int mask = (Integer)args[0];
|
||||||
if ((mask & MessagesController.UPDATE_MASK_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_NAME) != 0) {
|
if ((mask & MessagesController.UPDATE_MASK_AVATAR) != 0 || (mask & MessagesController.UPDATE_MASK_NAME) != 0) {
|
||||||
if (listView != null) {
|
if (listView != null) {
|
||||||
listView.invalidateViews();
|
listView.invalidateViews();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.contactsDidLoaded) {
|
} else if (id == NotificationCenter.contactsDidLoaded) {
|
||||||
createActionBarMenu();
|
createActionBarMenu();
|
||||||
} else if (id == MessagesController.mediaCountDidLoaded) {
|
} else if (id == NotificationCenter.mediaCountDidLoaded) {
|
||||||
long uid = (Long)args[0];
|
long uid = (Long)args[0];
|
||||||
if (uid > 0 && user_id == uid && dialog_id == 0 || dialog_id != 0 && dialog_id == uid) {
|
if (uid > 0 && user_id == uid && dialog_id == 0 || dialog_id != 0 && dialog_id == uid) {
|
||||||
totalMediaCount = (Integer)args[1];
|
totalMediaCount = (Integer)args[1];
|
||||||
@ -338,15 +337,15 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
listView.invalidateViews();
|
listView.invalidateViews();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.encryptedChatCreated) {
|
} else if (id == NotificationCenter.encryptedChatCreated) {
|
||||||
if (creatingChat) {
|
if (creatingChat) {
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.closeChats);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.closeChats);
|
||||||
TLRPC.EncryptedChat encryptedChat = (TLRPC.EncryptedChat)args[0];
|
TLRPC.EncryptedChat encryptedChat = (TLRPC.EncryptedChat)args[0];
|
||||||
Bundle args2 = new Bundle();
|
Bundle args2 = new Bundle();
|
||||||
args2.putInt("enc_id", encryptedChat.id);
|
args2.putInt("enc_id", encryptedChat.id);
|
||||||
presentFragment(new ChatActivity(args2), true);
|
presentFragment(new ChatActivity(args2), true);
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.encryptedChatUpdated) {
|
} else if (id == NotificationCenter.encryptedChatUpdated) {
|
||||||
TLRPC.EncryptedChat chat = (TLRPC.EncryptedChat)args[0];
|
TLRPC.EncryptedChat chat = (TLRPC.EncryptedChat)args[0];
|
||||||
if (currentEncryptedChat != null && chat.id == currentEncryptedChat.id) {
|
if (currentEncryptedChat != null && chat.id == currentEncryptedChat.id) {
|
||||||
currentEncryptedChat = chat;
|
currentEncryptedChat = chat;
|
||||||
@ -355,6 +354,12 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
listAdapter.notifyDataSetChanged();
|
listAdapter.notifyDataSetChanged();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else if (id == NotificationCenter.blockedUsersDidLoaded) {
|
||||||
|
boolean oldValue = userBlocked;
|
||||||
|
userBlocked = MessagesController.getInstance().blockedUsers.contains(user_id);
|
||||||
|
if (oldValue != userBlocked) {
|
||||||
|
createActionBarMenu();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -371,7 +376,7 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
if (fileLocation == null) {
|
if (fileLocation == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(user_id);
|
||||||
if (user != null && user.photo != null && user.photo.photo_big != null) {
|
if (user != null && user.photo != null && user.photo.photo_big != null) {
|
||||||
TLRPC.FileLocation photoBig = user.photo.photo_big;
|
TLRPC.FileLocation photoBig = user.photo.photo_big;
|
||||||
if (photoBig.local_id == fileLocation.local_id && photoBig.volume_id == fileLocation.volume_id && photoBig.dc_id == fileLocation.dc_id) {
|
if (photoBig.local_id == fileLocation.local_id && photoBig.volume_id == fileLocation.volume_id && photoBig.dc_id == fileLocation.dc_id) {
|
||||||
@ -424,21 +429,22 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
menu.clearItems();
|
menu.clearItems();
|
||||||
|
|
||||||
if (ContactsController.getInstance().contactsDict.get(user_id) == null) {
|
if (ContactsController.getInstance().contactsDict.get(user_id) == null) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(user_id);
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
ActionBarMenuItem item = menu.addItem(0, R.drawable.ic_ab_other);
|
ActionBarMenuItem item = menu.addItem(0, R.drawable.ic_ab_other);
|
||||||
if (user.phone != null && user.phone.length() != 0) {
|
if (user.phone != null && user.phone.length() != 0) {
|
||||||
item.addSubItem(add_contact, LocaleController.getString("AddContact", R.string.AddContact), 0);
|
item.addSubItem(add_contact, LocaleController.getString("AddContact", R.string.AddContact), 0);
|
||||||
item.addSubItem(block_contact, LocaleController.getString("BlockContact", R.string.BlockContact), 0);
|
item.addSubItem(share_contact, LocaleController.getString("ShareContact", R.string.ShareContact), 0);
|
||||||
|
item.addSubItem(block_contact, !userBlocked ? LocaleController.getString("BlockContact", R.string.BlockContact) : LocaleController.getString("Unblock", R.string.Unblock), 0);
|
||||||
} else {
|
} else {
|
||||||
item.addSubItem(block_contact, LocaleController.getString("BlockContact", R.string.BlockContact), 0);
|
item.addSubItem(block_contact, !userBlocked ? LocaleController.getString("BlockContact", R.string.BlockContact) : LocaleController.getString("Unblock", R.string.Unblock), 0);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
ActionBarMenuItem item = menu.addItem(0, R.drawable.ic_ab_other);
|
ActionBarMenuItem item = menu.addItem(0, R.drawable.ic_ab_other);
|
||||||
item.addSubItem(share_contact, LocaleController.getString("ShareContact", R.string.ShareContact), 0);
|
item.addSubItem(share_contact, LocaleController.getString("ShareContact", R.string.ShareContact), 0);
|
||||||
item.addSubItem(block_contact, LocaleController.getString("BlockContact", R.string.BlockContact), 0);
|
item.addSubItem(block_contact, !userBlocked ? LocaleController.getString("BlockContact", R.string.BlockContact) : LocaleController.getString("Unblock", R.string.Unblock), 0);
|
||||||
item.addSubItem(edit_contact, LocaleController.getString("EditContact", R.string.EditContact), 0);
|
item.addSubItem(edit_contact, LocaleController.getString("EditContact", R.string.EditContact), 0);
|
||||||
item.addSubItem(delete_contact, LocaleController.getString("DeleteContact", R.string.DeleteContact), 0);
|
item.addSubItem(delete_contact, LocaleController.getString("DeleteContact", R.string.DeleteContact), 0);
|
||||||
}
|
}
|
||||||
@ -449,7 +455,7 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
if (dialog_id != 0) {
|
if (dialog_id != 0) {
|
||||||
Bundle args = new Bundle();
|
Bundle args = new Bundle();
|
||||||
args.putBoolean("scrollToTopOnResume", true);
|
args.putBoolean("scrollToTopOnResume", true);
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.closeChats);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.closeChats);
|
||||||
int lower_part = (int)dialog_id;
|
int lower_part = (int)dialog_id;
|
||||||
if (lower_part != 0) {
|
if (lower_part != 0) {
|
||||||
if (lower_part > 0) {
|
if (lower_part > 0) {
|
||||||
@ -461,10 +467,9 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
args.putInt("enc_id", (int)(dialog_id >> 32));
|
args.putInt("enc_id", (int)(dialog_id >> 32));
|
||||||
}
|
}
|
||||||
presentFragment(new ChatActivity(args), true);
|
presentFragment(new ChatActivity(args), true);
|
||||||
messageFragment.removeSelfFromStack();
|
|
||||||
removeSelfFromStack();
|
removeSelfFromStack();
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(user_id);
|
||||||
MessagesController.getInstance().sendMessage(user, dialog_id);
|
SendMessagesHelper.getInstance().sendMessage(user, dialog_id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -511,7 +516,7 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
if (type == 0) {
|
if (type == 0) {
|
||||||
BackupImageView avatarImage;
|
BackupImageView avatarImage;
|
||||||
TextView onlineText;
|
TextView onlineText;
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(user_id);
|
||||||
if (view == null) {
|
if (view == null) {
|
||||||
LayoutInflater li = (LayoutInflater)mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
|
LayoutInflater li = (LayoutInflater)mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
|
||||||
view = li.inflate(R.layout.user_profile_avatar_layout, viewGroup, false);
|
view = li.inflate(R.layout.user_profile_avatar_layout, viewGroup, false);
|
||||||
@ -522,7 +527,7 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
avatarImage.setOnClickListener(new View.OnClickListener() {
|
avatarImage.setOnClickListener(new View.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(View view) {
|
public void onClick(View view) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(user_id);
|
||||||
if (user.photo != null && user.photo.photo_big != null) {
|
if (user.photo != null && user.photo.photo_big != null) {
|
||||||
PhotoViewer.getInstance().setParentActivity(getParentActivity());
|
PhotoViewer.getInstance().setParentActivity(getParentActivity());
|
||||||
PhotoViewer.getInstance().openPhoto(user.photo.photo_big, UserProfileActivity.this);
|
PhotoViewer.getInstance().openPhoto(user.photo.photo_big, UserProfileActivity.this);
|
||||||
@ -563,7 +568,7 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
textView.setText(LocaleController.getString("SHAREDMEDIA", R.string.SHAREDMEDIA));
|
textView.setText(LocaleController.getString("SHAREDMEDIA", R.string.SHAREDMEDIA));
|
||||||
}
|
}
|
||||||
} else if (type == 2) {
|
} else if (type == 2) {
|
||||||
final TLRPC.User user = MessagesController.getInstance().users.get(user_id);
|
final TLRPC.User user = MessagesController.getInstance().getUser(user_id);
|
||||||
if (view == null) {
|
if (view == null) {
|
||||||
LayoutInflater li = (LayoutInflater)mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
|
LayoutInflater li = (LayoutInflater)mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
|
||||||
view = li.inflate(R.layout.user_profile_phone_layout, viewGroup, false);
|
view = li.inflate(R.layout.user_profile_phone_layout, viewGroup, false);
|
||||||
@ -599,11 +604,11 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
button.setOnClickListener(new View.OnClickListener() {
|
button.setOnClickListener(new View.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(View view) {
|
public void onClick(View view) {
|
||||||
TLRPC.User user = MessagesController.getInstance().users.get(user_id);
|
TLRPC.User user = MessagesController.getInstance().getUser(user_id);
|
||||||
if (user == null || user instanceof TLRPC.TL_userEmpty) {
|
if (user == null || user instanceof TLRPC.TL_userEmpty) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
NotificationCenter.getInstance().postNotificationName(MessagesController.closeChats);
|
NotificationCenter.getInstance().postNotificationName(NotificationCenter.closeChats);
|
||||||
Bundle args = new Bundle();
|
Bundle args = new Bundle();
|
||||||
args.putInt("user_id", user_id);
|
args.putInt("user_id", user_id);
|
||||||
presentFragment(new ChatActivity(args), true);
|
presentFragment(new ChatActivity(args), true);
|
||||||
@ -656,7 +661,7 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
}
|
}
|
||||||
divider.setVisibility(View.INVISIBLE);
|
divider.setVisibility(View.INVISIBLE);
|
||||||
} else if (i == settingsTimerRow) {
|
} else if (i == settingsTimerRow) {
|
||||||
TLRPC.EncryptedChat encryptedChat = MessagesController.getInstance().encryptedChats.get((int)(dialog_id >> 32));
|
TLRPC.EncryptedChat encryptedChat = MessagesController.getInstance().getEncryptedChat((int)(dialog_id >> 32));
|
||||||
textView.setText(LocaleController.getString("MessageLifetime", R.string.MessageLifetime));
|
textView.setText(LocaleController.getString("MessageLifetime", R.string.MessageLifetime));
|
||||||
divider.setVisibility(View.VISIBLE);
|
divider.setVisibility(View.VISIBLE);
|
||||||
if (encryptedChat.ttl == 0) {
|
if (encryptedChat.ttl == 0) {
|
||||||
@ -686,7 +691,7 @@ public class UserProfileActivity extends BaseFragment implements NotificationCen
|
|||||||
View divider = view.findViewById(R.id.settings_row_divider);
|
View divider = view.findViewById(R.id.settings_row_divider);
|
||||||
divider.setVisibility(View.VISIBLE);
|
divider.setVisibility(View.VISIBLE);
|
||||||
IdenticonView identiconView = (IdenticonView)view.findViewById(R.id.identicon_view);
|
IdenticonView identiconView = (IdenticonView)view.findViewById(R.id.identicon_view);
|
||||||
TLRPC.EncryptedChat encryptedChat = MessagesController.getInstance().encryptedChats.get((int)(dialog_id >> 32));
|
TLRPC.EncryptedChat encryptedChat = MessagesController.getInstance().getEncryptedChat((int)(dialog_id >> 32));
|
||||||
identiconView.setBytes(encryptedChat.auth_key);
|
identiconView.setBytes(encryptedChat.auth_key);
|
||||||
textView.setText(LocaleController.getString("EncryptionKey", R.string.EncryptionKey));
|
textView.setText(LocaleController.getString("EncryptionKey", R.string.EncryptionKey));
|
||||||
} else if (type == 5) {
|
} else if (type == 5) {
|
||||||
|
@ -75,7 +75,7 @@ public class VideoEditorActivity extends BaseFragment implements SurfaceHolder.C
|
|||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
while (videoPlayer.isPlaying()) {
|
while (videoPlayer.isPlaying()) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
if (videoPlayer.isPlaying()) {
|
if (videoPlayer.isPlaying()) {
|
||||||
@ -123,7 +123,7 @@ public class VideoEditorActivity extends BaseFragment implements SurfaceHolder.C
|
|||||||
videoPlayer.setOnCompletionListener(new MediaPlayer.OnCompletionListener() {
|
videoPlayer.setOnCompletionListener(new MediaPlayer.OnCompletionListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onCompletion(MediaPlayer mp) {
|
public void onCompletion(MediaPlayer mp) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
onPlayComplete();
|
onPlayComplete();
|
||||||
|
@ -215,7 +215,12 @@ public class BaseFragment {
|
|||||||
@Override
|
@Override
|
||||||
public void onDismiss(DialogInterface dialog) {
|
public void onDismiss(DialogInterface dialog) {
|
||||||
visibleDialog = null;
|
visibleDialog = null;
|
||||||
|
onDialogDismiss();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void onDialogDismiss() {
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -16,10 +16,11 @@ import android.os.Bundle;
|
|||||||
import android.provider.MediaStore;
|
import android.provider.MediaStore;
|
||||||
|
|
||||||
import org.telegram.android.AndroidUtilities;
|
import org.telegram.android.AndroidUtilities;
|
||||||
|
import org.telegram.android.ImageLoader;
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.messenger.FileLoader;
|
import org.telegram.messenger.FileLoader;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
import org.telegram.messenger.Utilities;
|
import org.telegram.messenger.Utilities;
|
||||||
import org.telegram.ui.LaunchActivity;
|
import org.telegram.ui.LaunchActivity;
|
||||||
@ -93,7 +94,7 @@ public class AvatarUpdater implements NotificationCenter.NotificationCenterDeleg
|
|||||||
activity.presentFragment(photoCropActivity);
|
activity.presentFragment(photoCropActivity);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
FileLog.e("tmessages", e);
|
FileLog.e("tmessages", e);
|
||||||
Bitmap bitmap = FileLoader.loadBitmap(path, uri, 800, 800);
|
Bitmap bitmap = ImageLoader.loadBitmap(path, uri, 800, 800);
|
||||||
processBitmap(bitmap);
|
processBitmap(bitmap);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -118,8 +119,8 @@ public class AvatarUpdater implements NotificationCenter.NotificationCenterDeleg
|
|||||||
if (bitmap == null) {
|
if (bitmap == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
smallPhoto = FileLoader.scaleAndSaveImage(bitmap, 100, 100, 80, false);
|
smallPhoto = ImageLoader.scaleAndSaveImage(bitmap, 100, 100, 80, false);
|
||||||
bigPhoto = FileLoader.scaleAndSaveImage(bitmap, 800, 800, 80, false);
|
bigPhoto = ImageLoader.scaleAndSaveImage(bitmap, 800, 800, 80, false);
|
||||||
if (bigPhoto != null && smallPhoto != null) {
|
if (bigPhoto != null && smallPhoto != null) {
|
||||||
if (returnOnly) {
|
if (returnOnly) {
|
||||||
if (delegate != null) {
|
if (delegate != null) {
|
||||||
@ -128,8 +129,8 @@ public class AvatarUpdater implements NotificationCenter.NotificationCenterDeleg
|
|||||||
} else {
|
} else {
|
||||||
UserConfig.saveConfig(false);
|
UserConfig.saveConfig(false);
|
||||||
uploadingAvatar = AndroidUtilities.getCacheDir() + "/" + bigPhoto.location.volume_id + "_" + bigPhoto.location.local_id + ".jpg";
|
uploadingAvatar = AndroidUtilities.getCacheDir() + "/" + bigPhoto.location.volume_id + "_" + bigPhoto.location.local_id + ".jpg";
|
||||||
NotificationCenter.getInstance().addObserver(AvatarUpdater.this, FileLoader.FileDidUpload);
|
NotificationCenter.getInstance().addObserver(AvatarUpdater.this, NotificationCenter.FileDidUpload);
|
||||||
NotificationCenter.getInstance().addObserver(AvatarUpdater.this, FileLoader.FileDidFailUpload);
|
NotificationCenter.getInstance().addObserver(AvatarUpdater.this, NotificationCenter.FileDidFailUpload);
|
||||||
FileLoader.getInstance().uploadFile(uploadingAvatar, false);
|
FileLoader.getInstance().uploadFile(uploadingAvatar, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -142,14 +143,14 @@ public class AvatarUpdater implements NotificationCenter.NotificationCenterDeleg
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, final Object... args) {
|
public void didReceivedNotification(int id, final Object... args) {
|
||||||
if (id == FileLoader.FileDidUpload) {
|
if (id == NotificationCenter.FileDidUpload) {
|
||||||
String location = (String)args[0];
|
String location = (String)args[0];
|
||||||
if (uploadingAvatar != null && location.equals(uploadingAvatar)) {
|
if (uploadingAvatar != null && location.equals(uploadingAvatar)) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
NotificationCenter.getInstance().removeObserver(AvatarUpdater.this, FileLoader.FileDidUpload);
|
NotificationCenter.getInstance().removeObserver(AvatarUpdater.this, NotificationCenter.FileDidUpload);
|
||||||
NotificationCenter.getInstance().removeObserver(AvatarUpdater.this, FileLoader.FileDidFailUpload);
|
NotificationCenter.getInstance().removeObserver(AvatarUpdater.this, NotificationCenter.FileDidFailUpload);
|
||||||
if (delegate != null) {
|
if (delegate != null) {
|
||||||
delegate.didUploadedPhoto((TLRPC.InputFile)args[1], smallPhoto, bigPhoto);
|
delegate.didUploadedPhoto((TLRPC.InputFile)args[1], smallPhoto, bigPhoto);
|
||||||
}
|
}
|
||||||
@ -161,14 +162,14 @@ public class AvatarUpdater implements NotificationCenter.NotificationCenterDeleg
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
} else if (id == FileLoader.FileDidFailUpload) {
|
} else if (id == NotificationCenter.FileDidFailUpload) {
|
||||||
String location = (String)args[0];
|
String location = (String)args[0];
|
||||||
if (uploadingAvatar != null && location.equals(uploadingAvatar)) {
|
if (uploadingAvatar != null && location.equals(uploadingAvatar)) {
|
||||||
Utilities.RunOnUIThread(new Runnable() {
|
AndroidUtilities.RunOnUIThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
NotificationCenter.getInstance().removeObserver(AvatarUpdater.this, FileLoader.FileDidUpload);
|
NotificationCenter.getInstance().removeObserver(AvatarUpdater.this, NotificationCenter.FileDidUpload);
|
||||||
NotificationCenter.getInstance().removeObserver(AvatarUpdater.this, FileLoader.FileDidFailUpload);
|
NotificationCenter.getInstance().removeObserver(AvatarUpdater.this, NotificationCenter.FileDidFailUpload);
|
||||||
uploadingAvatar = null;
|
uploadingAvatar = null;
|
||||||
if (clearAfterUpdate) {
|
if (clearAfterUpdate) {
|
||||||
parentFragment = null;
|
parentFragment = null;
|
||||||
|
@ -16,6 +16,7 @@ import android.graphics.drawable.Drawable;
|
|||||||
import android.util.AttributeSet;
|
import android.util.AttributeSet;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
|
|
||||||
|
import org.telegram.android.ImageReceiver;
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
|
|
||||||
public class BackupImageView extends View {
|
public class BackupImageView extends View {
|
||||||
@ -38,8 +39,7 @@ public class BackupImageView extends View {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void init() {
|
private void init() {
|
||||||
imageReceiver = new ImageReceiver();
|
imageReceiver = new ImageReceiver(this);
|
||||||
imageReceiver.parentView = this;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setImage(TLRPC.FileLocation path, String filter, int placeholder) {
|
public void setImage(TLRPC.FileLocation path, String filter, int placeholder) {
|
||||||
@ -90,10 +90,7 @@ public class BackupImageView extends View {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onDraw(Canvas canvas) {
|
protected void onDraw(Canvas canvas) {
|
||||||
imageReceiver.imageX = 0;
|
imageReceiver.setImageCoords(0, 0, getWidth(), getHeight());
|
||||||
imageReceiver.imageY = 0;
|
imageReceiver.draw(canvas, 0, 0, getWidth(), getHeight());
|
||||||
imageReceiver.imageW = getWidth();
|
|
||||||
imageReceiver.imageH = getHeight();
|
|
||||||
imageReceiver.draw(canvas, 0, 0, imageReceiver.imageW, imageReceiver.imageH);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -37,9 +37,10 @@ import org.telegram.android.Emoji;
|
|||||||
import org.telegram.android.LocaleController;
|
import org.telegram.android.LocaleController;
|
||||||
import org.telegram.android.MediaController;
|
import org.telegram.android.MediaController;
|
||||||
import org.telegram.android.MessagesController;
|
import org.telegram.android.MessagesController;
|
||||||
|
import org.telegram.android.SendMessagesHelper;
|
||||||
import org.telegram.messenger.ConnectionsManager;
|
import org.telegram.messenger.ConnectionsManager;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.messenger.NotificationCenter;
|
import org.telegram.android.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.TLRPC;
|
import org.telegram.messenger.TLRPC;
|
||||||
import org.telegram.ui.ApplicationLoader;
|
import org.telegram.ui.ApplicationLoader;
|
||||||
@ -79,25 +80,25 @@ public class ChatActivityEnterView implements NotificationCenter.NotificationCen
|
|||||||
private ChatActivityEnterViewDelegate delegate;
|
private ChatActivityEnterViewDelegate delegate;
|
||||||
|
|
||||||
public ChatActivityEnterView() {
|
public ChatActivityEnterView() {
|
||||||
NotificationCenter.getInstance().addObserver(this, MediaController.recordStarted);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.recordStarted);
|
||||||
NotificationCenter.getInstance().addObserver(this, MediaController.recordStartError);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.recordStartError);
|
||||||
NotificationCenter.getInstance().addObserver(this, MediaController.recordStopped);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.recordStopped);
|
||||||
NotificationCenter.getInstance().addObserver(this, MediaController.recordProgressChanged);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.recordProgressChanged);
|
||||||
NotificationCenter.getInstance().addObserver(this, MessagesController.closeChats);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.closeChats);
|
||||||
NotificationCenter.getInstance().addObserver(this, MediaController.audioDidSent);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.audioDidSent);
|
||||||
NotificationCenter.getInstance().addObserver(this, 999);
|
NotificationCenter.getInstance().addObserver(this, NotificationCenter.emojiDidLoaded);
|
||||||
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("mainconfig", Activity.MODE_PRIVATE);
|
SharedPreferences preferences = ApplicationLoader.applicationContext.getSharedPreferences("mainconfig", Activity.MODE_PRIVATE);
|
||||||
sendByEnter = preferences.getBoolean("send_by_enter", false);
|
sendByEnter = preferences.getBoolean("send_by_enter", false);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void onDestroy() {
|
public void onDestroy() {
|
||||||
NotificationCenter.getInstance().removeObserver(this, MediaController.recordStarted);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.recordStarted);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MediaController.recordStartError);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.recordStartError);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MediaController.recordStopped);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.recordStopped);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MediaController.recordProgressChanged);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.recordProgressChanged);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MessagesController.closeChats);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.closeChats);
|
||||||
NotificationCenter.getInstance().removeObserver(this, MediaController.audioDidSent);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.audioDidSent);
|
||||||
NotificationCenter.getInstance().removeObserver(this, 999);
|
NotificationCenter.getInstance().removeObserver(this, NotificationCenter.emojiDidLoaded);
|
||||||
if (mWakeLock != null) {
|
if (mWakeLock != null) {
|
||||||
try {
|
try {
|
||||||
mWakeLock.release();
|
mWakeLock.release();
|
||||||
@ -266,7 +267,7 @@ public class ChatActivityEnterView implements NotificationCenter.NotificationCen
|
|||||||
int currentTime = ConnectionsManager.getInstance().getCurrentTime();
|
int currentTime = ConnectionsManager.getInstance().getCurrentTime();
|
||||||
TLRPC.User currentUser = null;
|
TLRPC.User currentUser = null;
|
||||||
if ((int)dialog_id > 0) {
|
if ((int)dialog_id > 0) {
|
||||||
currentUser = MessagesController.getInstance().users.get((int)dialog_id);
|
currentUser = MessagesController.getInstance().getUser((int)dialog_id);
|
||||||
}
|
}
|
||||||
if (currentUser != null && currentUser.status != null && currentUser.status.expires < currentTime) {
|
if (currentUser != null && currentUser.status != null && currentUser.status.expires < currentTime) {
|
||||||
return;
|
return;
|
||||||
@ -316,7 +317,7 @@ public class ChatActivityEnterView implements NotificationCenter.NotificationCen
|
|||||||
int count = (int)Math.ceil(text.length() / 2048.0f);
|
int count = (int)Math.ceil(text.length() / 2048.0f);
|
||||||
for (int a = 0; a < count; a++) {
|
for (int a = 0; a < count; a++) {
|
||||||
String mess = text.substring(a * 2048, Math.min((a + 1) * 2048, text.length()));
|
String mess = text.substring(a * 2048, Math.min((a + 1) * 2048, text.length()));
|
||||||
MessagesController.getInstance().sendMessage(mess, dialog_id);
|
SendMessagesHelper.getInstance().sendMessage(mess, dialog_id);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -612,11 +613,11 @@ public class ChatActivityEnterView implements NotificationCenter.NotificationCen
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, Object... args) {
|
public void didReceivedNotification(int id, Object... args) {
|
||||||
if (id == 999) {
|
if (id == NotificationCenter.emojiDidLoaded) {
|
||||||
if (emojiView != null) {
|
if (emojiView != null) {
|
||||||
emojiView.invalidateViews();
|
emojiView.invalidateViews();
|
||||||
}
|
}
|
||||||
} else if (id == MediaController.recordProgressChanged) {
|
} else if (id == NotificationCenter.recordProgressChanged) {
|
||||||
Long time = (Long)args[0] / 1000;
|
Long time = (Long)args[0] / 1000;
|
||||||
String str = String.format("%02d:%02d", time / 60, time % 60);
|
String str = String.format("%02d:%02d", time / 60, time % 60);
|
||||||
if (lastTimeString == null || !lastTimeString.equals(str)) {
|
if (lastTimeString == null || !lastTimeString.equals(str)) {
|
||||||
@ -624,21 +625,21 @@ public class ChatActivityEnterView implements NotificationCenter.NotificationCen
|
|||||||
recordTimeText.setText(str);
|
recordTimeText.setText(str);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (id == MessagesController.closeChats) {
|
} else if (id == NotificationCenter.closeChats) {
|
||||||
if (messsageEditText != null && messsageEditText.isFocused()) {
|
if (messsageEditText != null && messsageEditText.isFocused()) {
|
||||||
AndroidUtilities.hideKeyboard(messsageEditText);
|
AndroidUtilities.hideKeyboard(messsageEditText);
|
||||||
}
|
}
|
||||||
} else if (id == MediaController.recordStartError || id == MediaController.recordStopped) {
|
} else if (id == NotificationCenter.recordStartError || id == NotificationCenter.recordStopped) {
|
||||||
if (recordingAudio) {
|
if (recordingAudio) {
|
||||||
recordingAudio = false;
|
recordingAudio = false;
|
||||||
updateAudioRecordIntefrace();
|
updateAudioRecordIntefrace();
|
||||||
}
|
}
|
||||||
} else if (id == MediaController.recordStarted) {
|
} else if (id == NotificationCenter.recordStarted) {
|
||||||
if (!recordingAudio) {
|
if (!recordingAudio) {
|
||||||
recordingAudio = true;
|
recordingAudio = true;
|
||||||
updateAudioRecordIntefrace();
|
updateAudioRecordIntefrace();
|
||||||
}
|
}
|
||||||
} else if (id == MediaController.audioDidSent) {
|
} else if (id == NotificationCenter.audioDidSent) {
|
||||||
if (delegate != null) {
|
if (delegate != null) {
|
||||||
delegate.onMessageSend();
|
delegate.onMessageSend();
|
||||||
}
|
}
|
||||||
|
@ -19,10 +19,9 @@ import android.view.SoundEffectConstants;
|
|||||||
|
|
||||||
import org.telegram.android.AndroidUtilities;
|
import org.telegram.android.AndroidUtilities;
|
||||||
import org.telegram.android.MediaController;
|
import org.telegram.android.MediaController;
|
||||||
import org.telegram.android.MessagesController;
|
|
||||||
import org.telegram.messenger.FileLoader;
|
import org.telegram.messenger.FileLoader;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.objects.MessageObject;
|
import org.telegram.android.MessageObject;
|
||||||
import org.telegram.ui.Cells.BaseCell;
|
import org.telegram.ui.Cells.BaseCell;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
@ -100,12 +99,6 @@ public class PopupAudioView extends BaseCell implements SeekBar.SeekBarDelegate,
|
|||||||
currentMessageObject = messageObject;
|
currentMessageObject = messageObject;
|
||||||
wasLayout = false;
|
wasLayout = false;
|
||||||
|
|
||||||
if (currentMessageObject.messageOwner.id < 0 && currentMessageObject.messageOwner.send_state != MessagesController.MESSAGE_SEND_STATE_SEND_ERROR && currentMessageObject.messageOwner.send_state != MessagesController.MESSAGE_SEND_STATE_SENT) {
|
|
||||||
if (MessagesController.getInstance().sendingMessages.get(currentMessageObject.messageOwner.id) == null) {
|
|
||||||
currentMessageObject.messageOwner.send_state = MessagesController.MESSAGE_SEND_STATE_SEND_ERROR;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
requestLayout();
|
requestLayout();
|
||||||
}
|
}
|
||||||
updateButtonState();
|
updateButtonState();
|
||||||
@ -251,11 +244,11 @@ public class PopupAudioView extends BaseCell implements SeekBar.SeekBarDelegate,
|
|||||||
invalidate();
|
invalidate();
|
||||||
}
|
}
|
||||||
} else if (buttonState == 2) {
|
} else if (buttonState == 2) {
|
||||||
FileLoader.getInstance().loadFile(null, null, null, currentMessageObject.messageOwner.media.audio);
|
FileLoader.getInstance().loadFile(currentMessageObject.messageOwner.media.audio, true);
|
||||||
buttonState = 3;
|
buttonState = 3;
|
||||||
invalidate();
|
invalidate();
|
||||||
} else if (buttonState == 3) {
|
} else if (buttonState == 3) {
|
||||||
FileLoader.getInstance().cancelLoadFile(null, null, null, currentMessageObject.messageOwner.media.audio);
|
FileLoader.getInstance().cancelLoadFile(currentMessageObject.messageOwner.media.audio);
|
||||||
buttonState = 2;
|
buttonState = 2;
|
||||||
invalidate();
|
invalidate();
|
||||||
}
|
}
|
||||||
@ -286,7 +279,7 @@ public class PopupAudioView extends BaseCell implements SeekBar.SeekBarDelegate,
|
|||||||
|
|
||||||
public void downloadAudioIfNeed() {
|
public void downloadAudioIfNeed() {
|
||||||
if (buttonState == 2) {
|
if (buttonState == 2) {
|
||||||
FileLoader.getInstance().loadFile(null, null, null, currentMessageObject.messageOwner.media.audio);
|
FileLoader.getInstance().loadFile(currentMessageObject.messageOwner.media.audio, true);
|
||||||
buttonState = 3;
|
buttonState = 3;
|
||||||
invalidate();
|
invalidate();
|
||||||
}
|
}
|
||||||
@ -311,7 +304,7 @@ public class PopupAudioView extends BaseCell implements SeekBar.SeekBarDelegate,
|
|||||||
progressView.setProgress(0);
|
progressView.setProgress(0);
|
||||||
} else {
|
} else {
|
||||||
buttonState = 3;
|
buttonState = 3;
|
||||||
Float progress = FileLoader.getInstance().fileProgresses.get(fileName);
|
Float progress = FileLoader.getInstance().getFileProgress(fileName);
|
||||||
if (progress != null) {
|
if (progress != null) {
|
||||||
progressView.setProgress(progress);
|
progressView.setProgress(progress);
|
||||||
} else {
|
} else {
|
||||||
@ -335,6 +328,9 @@ public class PopupAudioView extends BaseCell implements SeekBar.SeekBarDelegate,
|
|||||||
@Override
|
@Override
|
||||||
public void onProgressDownload(String fileName, float progress) {
|
public void onProgressDownload(String fileName, float progress) {
|
||||||
progressView.setProgress(progress);
|
progressView.setProgress(progress);
|
||||||
|
if (buttonState != 3) {
|
||||||
|
updateButtonState();
|
||||||
|
}
|
||||||
invalidate();
|
invalidate();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -262,10 +262,7 @@
|
|||||||
android:layout_alignParentBottom="true"
|
android:layout_alignParentBottom="true"
|
||||||
android:background="#fbfcfd"
|
android:background="#fbfcfd"
|
||||||
android:id="@+id/bottom_overlay_chat"
|
android:id="@+id/bottom_overlay_chat"
|
||||||
android:visibility="gone"
|
android:visibility="gone">
|
||||||
android:focusable="true"
|
|
||||||
android:focusableInTouchMode="true"
|
|
||||||
android:clickable="true">
|
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
|
@ -58,12 +58,12 @@
|
|||||||
<string name="SelectChat">اختر محادثة</string>
|
<string name="SelectChat">اختر محادثة</string>
|
||||||
|
|
||||||
<!--broadcasts-->
|
<!--broadcasts-->
|
||||||
<string name="BroadcastList">Broadcast List</string>
|
<string name="BroadcastList">قائمة الرسالة الجماعية</string>
|
||||||
<string name="NewBroadcastList">New Broadcast List</string>
|
<string name="NewBroadcastList">قائمة رسالة جماعية جديدة</string>
|
||||||
<string name="EnterListName">Enter list name</string>
|
<string name="EnterListName">أدخل اسم القائمة</string>
|
||||||
<string name="YouCreatedBroadcastList">You created a broadcast list</string>
|
<string name="YouCreatedBroadcastList">أنت قمت بإنشاء قائمة رسالة جماعية</string>
|
||||||
<string name="AddRecipient">Add Recipient</string>
|
<string name="AddRecipient">إضافة مستلم</string>
|
||||||
<string name="KickFromBroadcast">Remove from broadcast list</string>
|
<string name="KickFromBroadcast">إزالة من قائمة الرسالة الجماعية</string>
|
||||||
|
|
||||||
<!--documents view-->
|
<!--documents view-->
|
||||||
<string name="SelectFile">اختر ملف</string>
|
<string name="SelectFile">اختر ملف</string>
|
||||||
@ -160,6 +160,7 @@
|
|||||||
<string name="NotificationContactJoined">%1$s قام بالتسجيل في تيليجرام!</string>
|
<string name="NotificationContactJoined">%1$s قام بالتسجيل في تيليجرام!</string>
|
||||||
<string name="NotificationUnrecognizedDevice">%1$s,\nتم تسجيل الدخول لحسابك من جهاز جديد يوم %2$s\n\nالجهاز: %3$s\nالموقع: %4$s\n\nإذا لم يكن أنت من سجل الدخول، يمكنك الذهاب للإعدادات ثم تسجيل الخروج من كافة الأجهزة الأخرى.\n\nشكرًا,\nفريق عمل تيليجرام</string>
|
<string name="NotificationUnrecognizedDevice">%1$s,\nتم تسجيل الدخول لحسابك من جهاز جديد يوم %2$s\n\nالجهاز: %3$s\nالموقع: %4$s\n\nإذا لم يكن أنت من سجل الدخول، يمكنك الذهاب للإعدادات ثم تسجيل الخروج من كافة الأجهزة الأخرى.\n\nشكرًا,\nفريق عمل تيليجرام</string>
|
||||||
<string name="NotificationContactNewPhoto">%1$s قام بتغيير صورته الشخصية</string>
|
<string name="NotificationContactNewPhoto">%1$s قام بتغيير صورته الشخصية</string>
|
||||||
|
<string name="Reply">Reply</string>
|
||||||
|
|
||||||
<!--contacts view-->
|
<!--contacts view-->
|
||||||
<string name="SelectContact">اختر جهة اتصال</string>
|
<string name="SelectContact">اختر جهة اتصال</string>
|
||||||
@ -254,10 +255,6 @@
|
|||||||
<string name="MessagesSettings">الرسائل</string>
|
<string name="MessagesSettings">الرسائل</string>
|
||||||
<string name="SendByEnter">أرسل بزر الإدخال</string>
|
<string name="SendByEnter">أرسل بزر الإدخال</string>
|
||||||
<string name="TerminateAllSessions">سجل الخروج من كافة الأجهزة الأخرى</string>
|
<string name="TerminateAllSessions">سجل الخروج من كافة الأجهزة الأخرى</string>
|
||||||
<string name="AutomaticPhotoDownload">تنزيل الصور تلقائيًا</string>
|
|
||||||
<string name="AutomaticAudioDownload">تنزيل رسائل الصوت تلقائياً</string>
|
|
||||||
<string name="AutomaticPhotoDownloadGroups">المجموعات</string>
|
|
||||||
<string name="AutomaticPhotoDownloadPrivateChats">المحادثات</string>
|
|
||||||
<string name="Events">الأحداث</string>
|
<string name="Events">الأحداث</string>
|
||||||
<string name="ContactJoined">اشترك صديق في تيليجرام</string>
|
<string name="ContactJoined">اشترك صديق في تيليجرام</string>
|
||||||
<string name="Pebble">PEBBLE</string>
|
<string name="Pebble">PEBBLE</string>
|
||||||
@ -284,6 +281,15 @@
|
|||||||
<string name="OnlyWhenScreenOff">فقط عندما تكون الشاشة مطفأة</string>
|
<string name="OnlyWhenScreenOff">فقط عندما تكون الشاشة مطفأة</string>
|
||||||
<string name="AlwaysShowPopup">دائمًا أظهر الإشعارات المنبثقة</string>
|
<string name="AlwaysShowPopup">دائمًا أظهر الإشعارات المنبثقة</string>
|
||||||
<string name="BadgeNumber">Badge Number</string>
|
<string name="BadgeNumber">Badge Number</string>
|
||||||
|
<string name="Short">Short</string>
|
||||||
|
<string name="Long">Long</string>
|
||||||
|
<string name="SystemDefault">System default</string>
|
||||||
|
<string name="SettingsDefault">Settings default</string>
|
||||||
|
<string name="AutomaticMediaDownload">AUTOMATIC MEDIA DOWNLOAD</string>
|
||||||
|
<string name="WhenUsingMobileData">When using mobile data</string>
|
||||||
|
<string name="WhenConnectedOnWiFi">When connected on Wi-Fi</string>
|
||||||
|
<string name="WhenRoaming">When roaming</string>
|
||||||
|
<string name="NoMediaAutoDownload">No media</string>
|
||||||
|
|
||||||
<!--media view-->
|
<!--media view-->
|
||||||
<string name="NoMedia">لا توجد وسائط بعد</string>
|
<string name="NoMedia">لا توجد وسائط بعد</string>
|
||||||
@ -309,8 +315,8 @@
|
|||||||
|
|
||||||
<!--edit video view-->
|
<!--edit video view-->
|
||||||
<string name="EditVideo">تحرير الفيديو</string>
|
<string name="EditVideo">تحرير الفيديو</string>
|
||||||
<string name="OriginalVideo">Original Video</string>
|
<string name="OriginalVideo">الفيديو الأصلي</string>
|
||||||
<string name="EditedVideo">Edited Video</string>
|
<string name="EditedVideo">تم تحرير الفيديو</string>
|
||||||
|
|
||||||
<!--button titles-->
|
<!--button titles-->
|
||||||
<string name="Next">التالي</string>
|
<string name="Next">التالي</string>
|
||||||
|
@ -160,6 +160,7 @@
|
|||||||
<string name="NotificationContactJoined">%1$s benutzt jetzt Telegram!</string>
|
<string name="NotificationContactJoined">%1$s benutzt jetzt Telegram!</string>
|
||||||
<string name="NotificationUnrecognizedDevice">%1$s,\nWir haben eine Anmeldung von einem neuen Gerät mit der IP-Adresse %2$s festgestellt.\n\nGerät: %3$s\nStandort: %4$s\n\nWenn du es nicht selbst gewesen bist, melde alle anderen Sitzungen in den Telegram Einstellungen unverzüglich ab. \n\n\nMit freundlichen Grüßen,\nDas Telegram Team</string>
|
<string name="NotificationUnrecognizedDevice">%1$s,\nWir haben eine Anmeldung von einem neuen Gerät mit der IP-Adresse %2$s festgestellt.\n\nGerät: %3$s\nStandort: %4$s\n\nWenn du es nicht selbst gewesen bist, melde alle anderen Sitzungen in den Telegram Einstellungen unverzüglich ab. \n\n\nMit freundlichen Grüßen,\nDas Telegram Team</string>
|
||||||
<string name="NotificationContactNewPhoto">%1$s hat das Profilbild geändert</string>
|
<string name="NotificationContactNewPhoto">%1$s hat das Profilbild geändert</string>
|
||||||
|
<string name="Reply">Reply</string>
|
||||||
|
|
||||||
<!--contacts view-->
|
<!--contacts view-->
|
||||||
<string name="SelectContact">Kontakt auswählen</string>
|
<string name="SelectContact">Kontakt auswählen</string>
|
||||||
@ -254,10 +255,6 @@
|
|||||||
<string name="MessagesSettings">NACHRICHTEN</string>
|
<string name="MessagesSettings">NACHRICHTEN</string>
|
||||||
<string name="SendByEnter">Mit ENTER senden</string>
|
<string name="SendByEnter">Mit ENTER senden</string>
|
||||||
<string name="TerminateAllSessions">Alle anderen Sitzungen beenden</string>
|
<string name="TerminateAllSessions">Alle anderen Sitzungen beenden</string>
|
||||||
<string name="AutomaticPhotoDownload">AUTOMATISCHER BILDER-DOWNLOAD</string>
|
|
||||||
<string name="AutomaticAudioDownload">AUTOMATISCHER AUDIO-DOWNLOAD</string>
|
|
||||||
<string name="AutomaticPhotoDownloadGroups">Gruppen</string>
|
|
||||||
<string name="AutomaticPhotoDownloadPrivateChats">Private Chats</string>
|
|
||||||
<string name="Events">EREIGNISSE</string>
|
<string name="Events">EREIGNISSE</string>
|
||||||
<string name="ContactJoined">Kontakt ist Telegram beigetreten</string>
|
<string name="ContactJoined">Kontakt ist Telegram beigetreten</string>
|
||||||
<string name="Pebble">PEBBLE</string>
|
<string name="Pebble">PEBBLE</string>
|
||||||
@ -284,6 +281,15 @@
|
|||||||
<string name="OnlyWhenScreenOff">Nur wenn Bildschirm „aus“</string>
|
<string name="OnlyWhenScreenOff">Nur wenn Bildschirm „aus“</string>
|
||||||
<string name="AlwaysShowPopup">Popups immer anzeigen</string>
|
<string name="AlwaysShowPopup">Popups immer anzeigen</string>
|
||||||
<string name="BadgeNumber">BADGE (Anzahl)</string>
|
<string name="BadgeNumber">BADGE (Anzahl)</string>
|
||||||
|
<string name="Short">Short</string>
|
||||||
|
<string name="Long">Long</string>
|
||||||
|
<string name="SystemDefault">System default</string>
|
||||||
|
<string name="SettingsDefault">Settings default</string>
|
||||||
|
<string name="AutomaticMediaDownload">AUTOMATIC MEDIA DOWNLOAD</string>
|
||||||
|
<string name="WhenUsingMobileData">When using mobile data</string>
|
||||||
|
<string name="WhenConnectedOnWiFi">When connected on Wi-Fi</string>
|
||||||
|
<string name="WhenRoaming">When roaming</string>
|
||||||
|
<string name="NoMediaAutoDownload">No media</string>
|
||||||
|
|
||||||
<!--media view-->
|
<!--media view-->
|
||||||
<string name="NoMedia">Noch keine geteilten Medien vorhanden</string>
|
<string name="NoMedia">Noch keine geteilten Medien vorhanden</string>
|
||||||
|
@ -160,6 +160,7 @@
|
|||||||
<string name="NotificationContactJoined">¡%1$s se unió a Telegram!</string>
|
<string name="NotificationContactJoined">¡%1$s se unió a Telegram!</string>
|
||||||
<string name="NotificationUnrecognizedDevice">%1$s,\nHemos detectado un inicio de sesión en tu cuenta desde un nuevo dispositivo, el %2$s\n\nDispositivo: %3$s\nUbicación: %4$s\n\nSi no eras tú, puedes ir a Ajustes - Cerrar todas las otras sesiones. \n\nAtentamente,\nEl Equipo de Telegram</string>
|
<string name="NotificationUnrecognizedDevice">%1$s,\nHemos detectado un inicio de sesión en tu cuenta desde un nuevo dispositivo, el %2$s\n\nDispositivo: %3$s\nUbicación: %4$s\n\nSi no eras tú, puedes ir a Ajustes - Cerrar todas las otras sesiones. \n\nAtentamente,\nEl Equipo de Telegram</string>
|
||||||
<string name="NotificationContactNewPhoto">%1$s actualizó su foto de perfil</string>
|
<string name="NotificationContactNewPhoto">%1$s actualizó su foto de perfil</string>
|
||||||
|
<string name="Reply">Reply</string>
|
||||||
|
|
||||||
<!--contacts view-->
|
<!--contacts view-->
|
||||||
<string name="SelectContact">Seleccionar contacto</string>
|
<string name="SelectContact">Seleccionar contacto</string>
|
||||||
@ -254,10 +255,6 @@
|
|||||||
<string name="MessagesSettings">MENSAJES</string>
|
<string name="MessagesSettings">MENSAJES</string>
|
||||||
<string name="SendByEnter">Enviar con \'Intro\'</string>
|
<string name="SendByEnter">Enviar con \'Intro\'</string>
|
||||||
<string name="TerminateAllSessions">Cerrar todas las otras sesiones</string>
|
<string name="TerminateAllSessions">Cerrar todas las otras sesiones</string>
|
||||||
<string name="AutomaticPhotoDownload">DESCARGA AUTOMÁTICA DE FOTOS</string>
|
|
||||||
<string name="AutomaticAudioDownload">DESCARGA AUTOMÁTICA DE AUDIO</string>
|
|
||||||
<string name="AutomaticPhotoDownloadGroups">Grupos</string>
|
|
||||||
<string name="AutomaticPhotoDownloadPrivateChats">Chats</string>
|
|
||||||
<string name="Events">EVENTOS</string>
|
<string name="Events">EVENTOS</string>
|
||||||
<string name="ContactJoined">Un contacto se unió a Telegram</string>
|
<string name="ContactJoined">Un contacto se unió a Telegram</string>
|
||||||
<string name="Pebble">PEBBLE</string>
|
<string name="Pebble">PEBBLE</string>
|
||||||
@ -284,6 +281,15 @@
|
|||||||
<string name="OnlyWhenScreenOff">Sólo con pantalla apagada</string>
|
<string name="OnlyWhenScreenOff">Sólo con pantalla apagada</string>
|
||||||
<string name="AlwaysShowPopup">Siempre mostrar notificación emergente</string>
|
<string name="AlwaysShowPopup">Siempre mostrar notificación emergente</string>
|
||||||
<string name="BadgeNumber">Globo en el ícono</string>
|
<string name="BadgeNumber">Globo en el ícono</string>
|
||||||
|
<string name="Short">Short</string>
|
||||||
|
<string name="Long">Long</string>
|
||||||
|
<string name="SystemDefault">System default</string>
|
||||||
|
<string name="SettingsDefault">Settings default</string>
|
||||||
|
<string name="AutomaticMediaDownload">AUTOMATIC MEDIA DOWNLOAD</string>
|
||||||
|
<string name="WhenUsingMobileData">When using mobile data</string>
|
||||||
|
<string name="WhenConnectedOnWiFi">When connected on Wi-Fi</string>
|
||||||
|
<string name="WhenRoaming">When roaming</string>
|
||||||
|
<string name="NoMediaAutoDownload">No media</string>
|
||||||
|
|
||||||
<!--media view-->
|
<!--media view-->
|
||||||
<string name="NoMedia">No hay fotos ni vídeos compartidos aún</string>
|
<string name="NoMedia">No hay fotos ni vídeos compartidos aún</string>
|
||||||
|
@ -160,6 +160,7 @@
|
|||||||
<string name="NotificationContactJoined">%1$s ha iniziato a usare Telegram!</string>
|
<string name="NotificationContactJoined">%1$s ha iniziato a usare Telegram!</string>
|
||||||
<string name="NotificationUnrecognizedDevice">%1$s,\nAbbiamo rilevato un accesso al tuo account da un nuovo dispositivo %2$s\n\nDispositivo: %3$s\nPosizione: %4$s\n\nSe non sei stato tu, puoi andare su Impostazioni - Termina tutte le sessioni.\n\nGrazie,\nIl Team di Telegram</string>
|
<string name="NotificationUnrecognizedDevice">%1$s,\nAbbiamo rilevato un accesso al tuo account da un nuovo dispositivo %2$s\n\nDispositivo: %3$s\nPosizione: %4$s\n\nSe non sei stato tu, puoi andare su Impostazioni - Termina tutte le sessioni.\n\nGrazie,\nIl Team di Telegram</string>
|
||||||
<string name="NotificationContactNewPhoto">%1$s ha aggiornato la foto del profilo</string>
|
<string name="NotificationContactNewPhoto">%1$s ha aggiornato la foto del profilo</string>
|
||||||
|
<string name="Reply">Reply</string>
|
||||||
|
|
||||||
<!--contacts view-->
|
<!--contacts view-->
|
||||||
<string name="SelectContact">Seleziona contatto</string>
|
<string name="SelectContact">Seleziona contatto</string>
|
||||||
@ -254,10 +255,6 @@
|
|||||||
<string name="MessagesSettings">MESSAGGI</string>
|
<string name="MessagesSettings">MESSAGGI</string>
|
||||||
<string name="SendByEnter">Spedisci con Invio</string>
|
<string name="SendByEnter">Spedisci con Invio</string>
|
||||||
<string name="TerminateAllSessions">Chiudi tutte le altre sessioni</string>
|
<string name="TerminateAllSessions">Chiudi tutte le altre sessioni</string>
|
||||||
<string name="AutomaticPhotoDownload">SCARICAMENTO AUTOMATICO FOTO</string>
|
|
||||||
<string name="AutomaticAudioDownload">SCARICAMENTO AUTOMATICO AUDIO</string>
|
|
||||||
<string name="AutomaticPhotoDownloadGroups">Gruppi</string>
|
|
||||||
<string name="AutomaticPhotoDownloadPrivateChats">Chat private</string>
|
|
||||||
<string name="Events">EVENTI</string>
|
<string name="Events">EVENTI</string>
|
||||||
<string name="ContactJoined">Un contatto si è collegato a Telegram</string>
|
<string name="ContactJoined">Un contatto si è collegato a Telegram</string>
|
||||||
<string name="Pebble">PEBBLE</string>
|
<string name="Pebble">PEBBLE</string>
|
||||||
@ -284,6 +281,15 @@
|
|||||||
<string name="OnlyWhenScreenOff">Solo con schermo spento</string>
|
<string name="OnlyWhenScreenOff">Solo con schermo spento</string>
|
||||||
<string name="AlwaysShowPopup">Mostra sempre i popup</string>
|
<string name="AlwaysShowPopup">Mostra sempre i popup</string>
|
||||||
<string name="BadgeNumber">Contatore Badge</string>
|
<string name="BadgeNumber">Contatore Badge</string>
|
||||||
|
<string name="Short">Short</string>
|
||||||
|
<string name="Long">Long</string>
|
||||||
|
<string name="SystemDefault">System default</string>
|
||||||
|
<string name="SettingsDefault">Settings default</string>
|
||||||
|
<string name="AutomaticMediaDownload">AUTOMATIC MEDIA DOWNLOAD</string>
|
||||||
|
<string name="WhenUsingMobileData">When using mobile data</string>
|
||||||
|
<string name="WhenConnectedOnWiFi">When connected on Wi-Fi</string>
|
||||||
|
<string name="WhenRoaming">When roaming</string>
|
||||||
|
<string name="NoMediaAutoDownload">No media</string>
|
||||||
|
|
||||||
<!--media view-->
|
<!--media view-->
|
||||||
<string name="NoMedia">Nessun media condiviso</string>
|
<string name="NoMedia">Nessun media condiviso</string>
|
||||||
|
@ -160,6 +160,7 @@
|
|||||||
<string name="NotificationContactJoined">%1$s heeft nu Telegram!</string>
|
<string name="NotificationContactJoined">%1$s heeft nu Telegram!</string>
|
||||||
<string name="NotificationUnrecognizedDevice">%1$s,\nEr is op je account ingelogd vanaf een nieuw apparaat op %2$s\n\nApparaat: %3$s\nLocatie: %4$s\n\nAls jij dit niet was, kun je alle sessies beëindigen via Instellingen – Beëindig alle andere sessies.\n\nBedankt,\nHet Telegram-team</string>
|
<string name="NotificationUnrecognizedDevice">%1$s,\nEr is op je account ingelogd vanaf een nieuw apparaat op %2$s\n\nApparaat: %3$s\nLocatie: %4$s\n\nAls jij dit niet was, kun je alle sessies beëindigen via Instellingen – Beëindig alle andere sessies.\n\nBedankt,\nHet Telegram-team</string>
|
||||||
<string name="NotificationContactNewPhoto">%1$s heeft zijn/haar profielfoto gewijzigd</string>
|
<string name="NotificationContactNewPhoto">%1$s heeft zijn/haar profielfoto gewijzigd</string>
|
||||||
|
<string name="Reply">Reply</string>
|
||||||
|
|
||||||
<!--contacts view-->
|
<!--contacts view-->
|
||||||
<string name="SelectContact">Kies een contact</string>
|
<string name="SelectContact">Kies een contact</string>
|
||||||
@ -254,10 +255,6 @@
|
|||||||
<string name="MessagesSettings">BERICHTEN</string>
|
<string name="MessagesSettings">BERICHTEN</string>
|
||||||
<string name="SendByEnter">Verzenden met Enter</string>
|
<string name="SendByEnter">Verzenden met Enter</string>
|
||||||
<string name="TerminateAllSessions">Beëindig alle andere sessies</string>
|
<string name="TerminateAllSessions">Beëindig alle andere sessies</string>
|
||||||
<string name="AutomaticPhotoDownload">FOTO\'S AUTOMATISCH DOWNLOADEN</string>
|
|
||||||
<string name="AutomaticAudioDownload">GELUIDSBESTANDEN AUTOMATISCH DOWNLOADEN</string>
|
|
||||||
<string name="AutomaticPhotoDownloadGroups">Groepen</string>
|
|
||||||
<string name="AutomaticPhotoDownloadPrivateChats">Privégesprekken</string>
|
|
||||||
<string name="Events">GEBEURTENISSEN</string>
|
<string name="Events">GEBEURTENISSEN</string>
|
||||||
<string name="ContactJoined">Contact lid geworden van Telegram</string>
|
<string name="ContactJoined">Contact lid geworden van Telegram</string>
|
||||||
<string name="Pebble">PEBBLE</string>
|
<string name="Pebble">PEBBLE</string>
|
||||||
@ -284,6 +281,15 @@
|
|||||||
<string name="OnlyWhenScreenOff">Alleen wanneer scherm \"uit\" staat</string>
|
<string name="OnlyWhenScreenOff">Alleen wanneer scherm \"uit\" staat</string>
|
||||||
<string name="AlwaysShowPopup">Altijd popup tonen</string>
|
<string name="AlwaysShowPopup">Altijd popup tonen</string>
|
||||||
<string name="BadgeNumber">Badgenummer</string>
|
<string name="BadgeNumber">Badgenummer</string>
|
||||||
|
<string name="Short">Short</string>
|
||||||
|
<string name="Long">Long</string>
|
||||||
|
<string name="SystemDefault">System default</string>
|
||||||
|
<string name="SettingsDefault">Settings default</string>
|
||||||
|
<string name="AutomaticMediaDownload">AUTOMATIC MEDIA DOWNLOAD</string>
|
||||||
|
<string name="WhenUsingMobileData">When using mobile data</string>
|
||||||
|
<string name="WhenConnectedOnWiFi">When connected on Wi-Fi</string>
|
||||||
|
<string name="WhenRoaming">When roaming</string>
|
||||||
|
<string name="NoMediaAutoDownload">No media</string>
|
||||||
|
|
||||||
<!--media view-->
|
<!--media view-->
|
||||||
<string name="NoMedia">Nog geen media gedeeld</string>
|
<string name="NoMedia">Nog geen media gedeeld</string>
|
||||||
|
@ -160,6 +160,7 @@
|
|||||||
<string name="NotificationContactJoined">%1$s entrou para o Telegram!</string>
|
<string name="NotificationContactJoined">%1$s entrou para o Telegram!</string>
|
||||||
<string name="NotificationUnrecognizedDevice">%1$s,\nNós detectamos um login na sua conta de um novo dispositivo %2$s\n\nDispositivo: %3$s\nLocalização: %4$s\n\nSe não foi você, você pode ir para Configurações - Terminar todas as sessões.\n\nAtenciosamente,\nTime do Telegram</string>
|
<string name="NotificationUnrecognizedDevice">%1$s,\nNós detectamos um login na sua conta de um novo dispositivo %2$s\n\nDispositivo: %3$s\nLocalização: %4$s\n\nSe não foi você, você pode ir para Configurações - Terminar todas as sessões.\n\nAtenciosamente,\nTime do Telegram</string>
|
||||||
<string name="NotificationContactNewPhoto">%1$s atualizou a foto do perfil</string>
|
<string name="NotificationContactNewPhoto">%1$s atualizou a foto do perfil</string>
|
||||||
|
<string name="Reply">Reply</string>
|
||||||
|
|
||||||
<!--contacts view-->
|
<!--contacts view-->
|
||||||
<string name="SelectContact">Selecionar Contato</string>
|
<string name="SelectContact">Selecionar Contato</string>
|
||||||
@ -254,10 +255,6 @@
|
|||||||
<string name="MessagesSettings">MENSAGENS</string>
|
<string name="MessagesSettings">MENSAGENS</string>
|
||||||
<string name="SendByEnter">Enviar usando \'Enter\'</string>
|
<string name="SendByEnter">Enviar usando \'Enter\'</string>
|
||||||
<string name="TerminateAllSessions">Terminar todas as outras sessões</string>
|
<string name="TerminateAllSessions">Terminar todas as outras sessões</string>
|
||||||
<string name="AutomaticPhotoDownload">BAIXAR FOTOS AUTOMÁTICAMENTE</string>
|
|
||||||
<string name="AutomaticAudioDownload">BAIXAR ÁUDIO AUTOMATICAMENTE</string>
|
|
||||||
<string name="AutomaticPhotoDownloadGroups">Grupos</string>
|
|
||||||
<string name="AutomaticPhotoDownloadPrivateChats">Conversas Privadas</string>
|
|
||||||
<string name="Events">EVENTOS</string>
|
<string name="Events">EVENTOS</string>
|
||||||
<string name="ContactJoined">Contato entrou para o Telegram</string>
|
<string name="ContactJoined">Contato entrou para o Telegram</string>
|
||||||
<string name="Pebble">PEBBLE</string>
|
<string name="Pebble">PEBBLE</string>
|
||||||
@ -284,6 +281,15 @@
|
|||||||
<string name="OnlyWhenScreenOff">Somente com a tela desligada</string>
|
<string name="OnlyWhenScreenOff">Somente com a tela desligada</string>
|
||||||
<string name="AlwaysShowPopup">Sempre mostrar popup</string>
|
<string name="AlwaysShowPopup">Sempre mostrar popup</string>
|
||||||
<string name="BadgeNumber">Contador de medalhas</string>
|
<string name="BadgeNumber">Contador de medalhas</string>
|
||||||
|
<string name="Short">Short</string>
|
||||||
|
<string name="Long">Long</string>
|
||||||
|
<string name="SystemDefault">System default</string>
|
||||||
|
<string name="SettingsDefault">Settings default</string>
|
||||||
|
<string name="AutomaticMediaDownload">AUTOMATIC MEDIA DOWNLOAD</string>
|
||||||
|
<string name="WhenUsingMobileData">When using mobile data</string>
|
||||||
|
<string name="WhenConnectedOnWiFi">When connected on Wi-Fi</string>
|
||||||
|
<string name="WhenRoaming">When roaming</string>
|
||||||
|
<string name="NoMediaAutoDownload">No media</string>
|
||||||
|
|
||||||
<!--media view-->
|
<!--media view-->
|
||||||
<string name="NoMedia">Ainda não há mídia compartilhada</string>
|
<string name="NoMedia">Ainda não há mídia compartilhada</string>
|
||||||
|
@ -160,6 +160,7 @@
|
|||||||
<string name="NotificationContactJoined">%1$s aderiu ao Telegram!</string>
|
<string name="NotificationContactJoined">%1$s aderiu ao Telegram!</string>
|
||||||
<string name="NotificationUnrecognizedDevice">%1$s,\nDetetámos um acesso à sua conta a partir de um novo dispositivo o dia %2$s\n\nDispositivo: %3$s\nLocalização: %4$s\n\nSe não foi você, pode ir a Definições - Terminar todas as sessões.\n\nObrigado,\nA equipa do Telegram</string>
|
<string name="NotificationUnrecognizedDevice">%1$s,\nDetetámos um acesso à sua conta a partir de um novo dispositivo o dia %2$s\n\nDispositivo: %3$s\nLocalização: %4$s\n\nSe não foi você, pode ir a Definições - Terminar todas as sessões.\n\nObrigado,\nA equipa do Telegram</string>
|
||||||
<string name="NotificationContactNewPhoto">%1$s atualizou a sua foto de perfil</string>
|
<string name="NotificationContactNewPhoto">%1$s atualizou a sua foto de perfil</string>
|
||||||
|
<string name="Reply">Reply</string>
|
||||||
|
|
||||||
<!--contacts view-->
|
<!--contacts view-->
|
||||||
<string name="SelectContact">Selecionar contacto</string>
|
<string name="SelectContact">Selecionar contacto</string>
|
||||||
@ -254,10 +255,6 @@
|
|||||||
<string name="MessagesSettings">MENSAGENS</string>
|
<string name="MessagesSettings">MENSAGENS</string>
|
||||||
<string name="SendByEnter">Enviar com Enter</string>
|
<string name="SendByEnter">Enviar com Enter</string>
|
||||||
<string name="TerminateAllSessions">Terminar todas as outras sessões</string>
|
<string name="TerminateAllSessions">Terminar todas as outras sessões</string>
|
||||||
<string name="AutomaticPhotoDownload">TRANSFERÊNCIA AUTOMÁTICA DE FOTOS</string>
|
|
||||||
<string name="AutomaticAudioDownload">TRANSFERÊNCIA AUTOMÁTICA DE ÁUDIO</string>
|
|
||||||
<string name="AutomaticPhotoDownloadGroups">Grupos</string>
|
|
||||||
<string name="AutomaticPhotoDownloadPrivateChats">Chats privados</string>
|
|
||||||
<string name="Events">EVENTOS</string>
|
<string name="Events">EVENTOS</string>
|
||||||
<string name="ContactJoined">Contactos que aderem ao Telegram</string>
|
<string name="ContactJoined">Contactos que aderem ao Telegram</string>
|
||||||
<string name="Pebble">PEBBLE</string>
|
<string name="Pebble">PEBBLE</string>
|
||||||
@ -284,6 +281,15 @@
|
|||||||
<string name="OnlyWhenScreenOff">Only when screen "off"</string>
|
<string name="OnlyWhenScreenOff">Only when screen "off"</string>
|
||||||
<string name="AlwaysShowPopup">Always show popup</string>
|
<string name="AlwaysShowPopup">Always show popup</string>
|
||||||
<string name="BadgeNumber">Badge Number</string>
|
<string name="BadgeNumber">Badge Number</string>
|
||||||
|
<string name="Short">Short</string>
|
||||||
|
<string name="Long">Long</string>
|
||||||
|
<string name="SystemDefault">System default</string>
|
||||||
|
<string name="SettingsDefault">Settings default</string>
|
||||||
|
<string name="AutomaticMediaDownload">AUTOMATIC MEDIA DOWNLOAD</string>
|
||||||
|
<string name="WhenUsingMobileData">When using mobile data</string>
|
||||||
|
<string name="WhenConnectedOnWiFi">When connected on Wi-Fi</string>
|
||||||
|
<string name="WhenRoaming">When roaming</string>
|
||||||
|
<string name="NoMediaAutoDownload">No media</string>
|
||||||
|
|
||||||
<!--media view-->
|
<!--media view-->
|
||||||
<string name="NoMedia">Ainda não há multimédia partilhado</string>
|
<string name="NoMedia">Ainda não há multimédia partilhado</string>
|
||||||
|
@ -160,6 +160,7 @@
|
|||||||
<string name="NotificationContactJoined">%1$s joined Telegram!</string>
|
<string name="NotificationContactJoined">%1$s joined Telegram!</string>
|
||||||
<string name="NotificationUnrecognizedDevice">%1$s,\nWe detected a login into your account from a new device on %2$s\n\nDevice: %3$s\nLocation: %4$s\n\nIf this wasn\'t you, you can go to Settings - Terminate all sessions.\n\nSincerely,\nThe Telegram Team</string>
|
<string name="NotificationUnrecognizedDevice">%1$s,\nWe detected a login into your account from a new device on %2$s\n\nDevice: %3$s\nLocation: %4$s\n\nIf this wasn\'t you, you can go to Settings - Terminate all sessions.\n\nSincerely,\nThe Telegram Team</string>
|
||||||
<string name="NotificationContactNewPhoto">%1$s updated profile photo</string>
|
<string name="NotificationContactNewPhoto">%1$s updated profile photo</string>
|
||||||
|
<string name="Reply">Reply</string>
|
||||||
|
|
||||||
<!--contacts view-->
|
<!--contacts view-->
|
||||||
<string name="SelectContact">Select Contact</string>
|
<string name="SelectContact">Select Contact</string>
|
||||||
@ -254,10 +255,6 @@
|
|||||||
<string name="MessagesSettings">MESSAGES</string>
|
<string name="MessagesSettings">MESSAGES</string>
|
||||||
<string name="SendByEnter">Send by Enter</string>
|
<string name="SendByEnter">Send by Enter</string>
|
||||||
<string name="TerminateAllSessions">Terminate All Other Sessions</string>
|
<string name="TerminateAllSessions">Terminate All Other Sessions</string>
|
||||||
<string name="AutomaticPhotoDownload">AUTOMATIC PHOTO DOWNLOAD</string>
|
|
||||||
<string name="AutomaticAudioDownload">AUTOMATIC AUDIO DOWNLOAD</string>
|
|
||||||
<string name="AutomaticPhotoDownloadGroups">Groups</string>
|
|
||||||
<string name="AutomaticPhotoDownloadPrivateChats">Private Chats</string>
|
|
||||||
<string name="Events">EVENTS</string>
|
<string name="Events">EVENTS</string>
|
||||||
<string name="ContactJoined">Contact joined Telegram</string>
|
<string name="ContactJoined">Contact joined Telegram</string>
|
||||||
<string name="Pebble">PEBBLE</string>
|
<string name="Pebble">PEBBLE</string>
|
||||||
@ -284,6 +281,15 @@
|
|||||||
<string name="OnlyWhenScreenOff">Only when screen "off"</string>
|
<string name="OnlyWhenScreenOff">Only when screen "off"</string>
|
||||||
<string name="AlwaysShowPopup">Always show popup</string>
|
<string name="AlwaysShowPopup">Always show popup</string>
|
||||||
<string name="BadgeNumber">Badge Counter</string>
|
<string name="BadgeNumber">Badge Counter</string>
|
||||||
|
<string name="Short">Short</string>
|
||||||
|
<string name="Long">Long</string>
|
||||||
|
<string name="SystemDefault">System default</string>
|
||||||
|
<string name="SettingsDefault">Settings default</string>
|
||||||
|
<string name="AutomaticMediaDownload">AUTOMATIC MEDIA DOWNLOAD</string>
|
||||||
|
<string name="WhenUsingMobileData">When using mobile data</string>
|
||||||
|
<string name="WhenConnectedOnWiFi">When connected on Wi-Fi</string>
|
||||||
|
<string name="WhenRoaming">When roaming</string>
|
||||||
|
<string name="NoMediaAutoDownload">No media</string>
|
||||||
|
|
||||||
<!--media view-->
|
<!--media view-->
|
||||||
<string name="NoMedia">No shared media yet</string>
|
<string name="NoMedia">No shared media yet</string>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user