mirror of
https://github.com/DrKLO/Telegram.git
synced 2024-12-31 16:40:45 +01:00
update to 9.3.3
This commit is contained in:
parent
5a31f93ec2
commit
1c03d75ea8
29 changed files with 517 additions and 112 deletions
|
@ -24,8 +24,8 @@ public class BuildVars {
|
||||||
public static boolean USE_CLOUD_STRINGS = true;
|
public static boolean USE_CLOUD_STRINGS = true;
|
||||||
public static boolean CHECK_UPDATES = true;
|
public static boolean CHECK_UPDATES = true;
|
||||||
public static boolean NO_SCOPED_STORAGE = Build.VERSION.SDK_INT <= 29;
|
public static boolean NO_SCOPED_STORAGE = Build.VERSION.SDK_INT <= 29;
|
||||||
public static int BUILD_VERSION = 3023;
|
public static int BUILD_VERSION = 3026;
|
||||||
public static String BUILD_VERSION_STRING = "9.3.2";
|
public static String BUILD_VERSION_STRING = "9.3.3";
|
||||||
public static int APP_ID = 4;
|
public static int APP_ID = 4;
|
||||||
public static String APP_HASH = "014b35b6184100b085b0d0572f9b5103";
|
public static String APP_HASH = "014b35b6184100b085b0d0572f9b5103";
|
||||||
|
|
||||||
|
|
|
@ -1212,6 +1212,12 @@ public class DatabaseMigrationHelper {
|
||||||
version = 110;
|
version = 110;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (version == 110) {
|
||||||
|
database.executeFast("CREATE TABLE stickersets(id INTEGER PRIMATE KEY, data BLOB, hash INTEGER);").stepThis().dispose();
|
||||||
|
database.executeFast("PRAGMA user_version = 111").stepThis().dispose();
|
||||||
|
version = 111;
|
||||||
|
}
|
||||||
|
|
||||||
return version;
|
return version;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -71,7 +71,7 @@ public class FileLog {
|
||||||
private static HashSet<String> excludeRequests;
|
private static HashSet<String> excludeRequests;
|
||||||
|
|
||||||
public static void dumpResponseAndRequest(TLObject request, TLObject response, TLRPC.TL_error error, long requestMsgId, long startRequestTimeInMillis, int requestToken) {
|
public static void dumpResponseAndRequest(TLObject request, TLObject response, TLRPC.TL_error error, long requestMsgId, long startRequestTimeInMillis, int requestToken) {
|
||||||
if (!BuildVars.DEBUG_PRIVATE_VERSION || !BuildVars.LOGS_ENABLED || request == null || SharedConfig.getDevicePerformanceClass() != SharedConfig.PERFORMANCE_CLASS_LOW) {
|
if (!BuildVars.DEBUG_PRIVATE_VERSION || !BuildVars.LOGS_ENABLED || request == null || SharedConfig.getDevicePerformanceClass() == SharedConfig.PERFORMANCE_CLASS_LOW) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
String requestSimpleName = request.getClass().getSimpleName();
|
String requestSimpleName = request.getClass().getSimpleName();
|
||||||
|
@ -119,6 +119,7 @@ public class FileLog {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
|
checkGson();
|
||||||
getInstance().dateFormat.format(System.currentTimeMillis());
|
getInstance().dateFormat.format(System.currentTimeMillis());
|
||||||
String messageStr = "receive message -> " + message.getClass().getSimpleName() + " : " + gson.toJson(message);
|
String messageStr = "receive message -> " + message.getClass().getSimpleName() + " : " + gson.toJson(message);
|
||||||
String res = "null";
|
String res = "null";
|
||||||
|
|
|
@ -2775,15 +2775,19 @@ public class ImageReceiver implements NotificationCenter.NotificationCenterDeleg
|
||||||
if (type == TYPE_MEDIA) {
|
if (type == TYPE_MEDIA) {
|
||||||
currentMediaKey = null;
|
currentMediaKey = null;
|
||||||
currentMediaDrawable = null;
|
currentMediaDrawable = null;
|
||||||
|
mediaShader = null;
|
||||||
} else if (type == TYPE_CROSSFDADE) {
|
} else if (type == TYPE_CROSSFDADE) {
|
||||||
crossfadeKey = null;
|
crossfadeKey = null;
|
||||||
crossfadeImage = null;
|
crossfadeImage = null;
|
||||||
|
crossfadeShader = null;
|
||||||
} else if (type == TYPE_THUMB) {
|
} else if (type == TYPE_THUMB) {
|
||||||
currentThumbDrawable = null;
|
currentThumbDrawable = null;
|
||||||
currentThumbKey = null;
|
currentThumbKey = null;
|
||||||
|
thumbShader = null;
|
||||||
} else {
|
} else {
|
||||||
currentImageDrawable = null;
|
currentImageDrawable = null;
|
||||||
currentImageKey = null;
|
currentImageKey = null;
|
||||||
|
imageShader = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -701,6 +701,7 @@ public class MediaDataController extends BaseController {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
imageReceiver.setUniqKeyPrefix("preload");
|
imageReceiver.setUniqKeyPrefix("preload");
|
||||||
|
imageReceiver.setFileLoadingPriority(FileLoader.PRIORITY_LOW);
|
||||||
imageReceiver.setImage(location, filter, null, null, 0, FileLoader.PRELOAD_CACHE_TYPE);
|
imageReceiver.setImage(location, filter, null, null, 0, FileLoader.PRELOAD_CACHE_TYPE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1083,10 +1084,14 @@ public class MediaDataController extends BaseController {
|
||||||
}
|
}
|
||||||
|
|
||||||
public TLRPC.TL_messages_stickerSet getStickerSet(TLRPC.InputStickerSet inputStickerSet, boolean cacheOnly) {
|
public TLRPC.TL_messages_stickerSet getStickerSet(TLRPC.InputStickerSet inputStickerSet, boolean cacheOnly) {
|
||||||
return getStickerSet(inputStickerSet, cacheOnly, null);
|
return getStickerSet(inputStickerSet, null, cacheOnly, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
public TLRPC.TL_messages_stickerSet getStickerSet(TLRPC.InputStickerSet inputStickerSet, boolean cacheOnly, Utilities.Callback<TLRPC.TL_messages_stickerSet> onResponse) {
|
public TLRPC.TL_messages_stickerSet getStickerSet(TLRPC.InputStickerSet inputStickerSet, Integer hash, boolean cacheOnly) {
|
||||||
|
return getStickerSet(inputStickerSet, hash, cacheOnly, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
public TLRPC.TL_messages_stickerSet getStickerSet(TLRPC.InputStickerSet inputStickerSet, Integer hash, boolean cacheOnly, Utilities.Callback<TLRPC.TL_messages_stickerSet> onResponse) {
|
||||||
if (inputStickerSet == null) {
|
if (inputStickerSet == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -1104,39 +1109,151 @@ public class MediaDataController extends BaseController {
|
||||||
}
|
}
|
||||||
return cacheSet;
|
return cacheSet;
|
||||||
}
|
}
|
||||||
if (cacheOnly) {
|
if (inputStickerSet instanceof TLRPC.TL_inputStickerSetID && hash != null) {
|
||||||
return null;
|
getMessagesStorage().getStorageQueue().postRunnable(() -> {
|
||||||
}
|
TLRPC.TL_messages_stickerSet cachedSet = getCachedStickerSetInternal(inputStickerSet.id, hash);
|
||||||
TLRPC.TL_messages_getStickerSet req = new TLRPC.TL_messages_getStickerSet();
|
|
||||||
req.stickerset = inputStickerSet;
|
|
||||||
getConnectionsManager().sendRequest(req, (response, error) -> {
|
|
||||||
if (response != null) {
|
|
||||||
TLRPC.TL_messages_stickerSet set = (TLRPC.TL_messages_stickerSet) response;
|
|
||||||
AndroidUtilities.runOnUIThread(() -> {
|
AndroidUtilities.runOnUIThread(() -> {
|
||||||
if (set == null || set.set == null) {
|
if (cachedSet != null) {
|
||||||
return;
|
if (onResponse != null) {
|
||||||
|
onResponse.run(cachedSet);
|
||||||
}
|
}
|
||||||
|
if (cachedSet.set != null) {
|
||||||
|
stickerSetsById.put(cachedSet.set.id, cachedSet);
|
||||||
|
stickerSetsByName.put(cachedSet.set.short_name.toLowerCase(), cachedSet);
|
||||||
|
}
|
||||||
|
getNotificationCenter().postNotificationName(NotificationCenter.groupStickersDidLoad, cachedSet.set.id, cachedSet);
|
||||||
|
} else {
|
||||||
|
fetchStickerSetInternal(inputStickerSet, (ok, set) -> {
|
||||||
|
if (onResponse != null) {
|
||||||
|
onResponse.run(set);
|
||||||
|
}
|
||||||
|
if (set != null && set.set != null) {
|
||||||
|
stickerSetsById.put(set.set.id, set);
|
||||||
|
stickerSetsByName.put(set.set.short_name.toLowerCase(), set);
|
||||||
|
saveStickerSetIntoCache(set);
|
||||||
|
getNotificationCenter().postNotificationName(NotificationCenter.groupStickersDidLoad, set.set.id, set);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
} else if (!cacheOnly) {
|
||||||
|
fetchStickerSetInternal(inputStickerSet, (ok, set) -> {
|
||||||
|
if (onResponse != null) {
|
||||||
|
onResponse.run(set);
|
||||||
|
}
|
||||||
|
if (set != null) {
|
||||||
|
if (set.set != null) {
|
||||||
stickerSetsById.put(set.set.id, set);
|
stickerSetsById.put(set.set.id, set);
|
||||||
stickerSetsByName.put(set.set.short_name.toLowerCase(), set);
|
stickerSetsByName.put(set.set.short_name.toLowerCase(), set);
|
||||||
if (inputStickerSet instanceof TLRPC.TL_inputStickerSetEmojiDefaultStatuses) {
|
if (inputStickerSet instanceof TLRPC.TL_inputStickerSetEmojiDefaultStatuses) {
|
||||||
stickerSetDefaultStatuses = set;
|
stickerSetDefaultStatuses = set;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
saveStickerSetIntoCache(set);
|
||||||
getNotificationCenter().postNotificationName(NotificationCenter.groupStickersDidLoad, set.set.id, set);
|
getNotificationCenter().postNotificationName(NotificationCenter.groupStickersDidLoad, set.set.id, set);
|
||||||
if (onResponse != null) {
|
|
||||||
onResponse.run(set);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
AndroidUtilities.runOnUIThread(() -> {
|
|
||||||
if (onResponse != null) {
|
|
||||||
onResponse.run(null);
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
});
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void saveStickerSetIntoCache(TLRPC.TL_messages_stickerSet set) {
|
||||||
|
if (set == null || set.set == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
getMessagesStorage().getStorageQueue().postRunnable(() -> {
|
||||||
|
try {
|
||||||
|
SQLitePreparedStatement state = getMessagesStorage().getDatabase().executeFast("REPLACE INTO stickersets VALUES(?, ?, ?)");
|
||||||
|
state.requery();
|
||||||
|
NativeByteBuffer data = new NativeByteBuffer(set.getObjectSize());
|
||||||
|
set.serializeToStream(data);
|
||||||
|
state.bindLong(1, set.set.id);
|
||||||
|
state.bindByteBuffer(2, data);
|
||||||
|
state.bindInteger(3, set.set.hash);
|
||||||
|
state.step();
|
||||||
|
data.reuse();
|
||||||
|
state.dispose();
|
||||||
|
} catch (Exception e) {
|
||||||
|
FileLog.e(e);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private TLRPC.TL_messages_stickerSet getCachedStickerSetInternal(long id, Integer hash) {
|
||||||
|
TLRPC.TL_messages_stickerSet set = null;
|
||||||
|
SQLiteCursor cursor = null;
|
||||||
|
NativeByteBuffer data = null;
|
||||||
|
try {
|
||||||
|
cursor = getMessagesStorage().getDatabase().queryFinalized("SELECT data, hash FROM stickersets WHERE id = " + id + " LIMIT 1");
|
||||||
|
if (cursor.next() && !cursor.isNull(0)) {
|
||||||
|
data = cursor.byteBufferValue(0);
|
||||||
|
if (data != null) {
|
||||||
|
set = TLRPC.TL_messages_stickerSet.TLdeserialize(data, data.readInt32(false), false);
|
||||||
|
int cachedHash = cursor.intValue(1);
|
||||||
|
if (hash != null && hash != cachedHash) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (Throwable e) {
|
||||||
|
FileLog.e(e);
|
||||||
|
} finally {
|
||||||
|
if (data != null) {
|
||||||
|
data.reuse();
|
||||||
|
}
|
||||||
|
if (cursor != null) {
|
||||||
|
cursor.dispose();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return set;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void fetchStickerSetInternal(long id, Integer hash, Utilities.Callback2<Boolean, TLRPC.TL_messages_stickerSet> onDone) {
|
||||||
|
if (onDone == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
TLRPC.TL_messages_getStickerSet req = new TLRPC.TL_messages_getStickerSet();
|
||||||
|
TLRPC.TL_inputStickerSetID inputStickerSetID = new TLRPC.TL_inputStickerSetID();
|
||||||
|
inputStickerSetID.id = id;
|
||||||
|
req.stickerset = inputStickerSetID;
|
||||||
|
if (hash != null) {
|
||||||
|
req.hash = hash;
|
||||||
|
}
|
||||||
|
getConnectionsManager().sendRequest(req, (response, error) -> {
|
||||||
|
AndroidUtilities.runOnUIThread(() -> {
|
||||||
|
// if (error != null && "".equals(error.text)) {
|
||||||
|
// onDone.run(true, null);
|
||||||
|
// } else
|
||||||
|
if (response != null) {
|
||||||
|
onDone.run(true, (TLRPC.TL_messages_stickerSet) response);
|
||||||
|
} else {
|
||||||
|
onDone.run(false, null);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void fetchStickerSetInternal(TLRPC.InputStickerSet inputStickerSet, Utilities.Callback2<Boolean, TLRPC.TL_messages_stickerSet> onDone) {
|
||||||
|
if (onDone == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
TLRPC.TL_messages_getStickerSet req = new TLRPC.TL_messages_getStickerSet();
|
||||||
|
req.stickerset = inputStickerSet;
|
||||||
|
getConnectionsManager().sendRequest(req, (response, error) -> {
|
||||||
|
AndroidUtilities.runOnUIThread(() -> {
|
||||||
|
// if (error != null && "".equals(error.text)) {
|
||||||
|
// onDone.run(true, null);
|
||||||
|
// } else
|
||||||
|
if (response != null) {
|
||||||
|
onDone.run(true, (TLRPC.TL_messages_stickerSet) response);
|
||||||
|
} else {
|
||||||
|
onDone.run(false, null);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
private void loadGroupStickerSet(TLRPC.StickerSet stickerSet, boolean cache) {
|
private void loadGroupStickerSet(TLRPC.StickerSet stickerSet, boolean cache) {
|
||||||
if (cache) {
|
if (cache) {
|
||||||
getMessagesStorage().getStorageQueue().postRunnable(() -> {
|
getMessagesStorage().getStorageQueue().postRunnable(() -> {
|
||||||
|
|
|
@ -15,7 +15,6 @@ import android.text.SpannableStringBuilder;
|
||||||
import android.text.Spanned;
|
import android.text.Spanned;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
import android.text.style.ForegroundColorSpan;
|
import android.text.style.ForegroundColorSpan;
|
||||||
import android.util.Log;
|
|
||||||
import android.util.Pair;
|
import android.util.Pair;
|
||||||
import android.util.SparseArray;
|
import android.util.SparseArray;
|
||||||
import android.util.SparseIntArray;
|
import android.util.SparseIntArray;
|
||||||
|
@ -94,7 +93,7 @@ public class MessagesStorage extends BaseController {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private final static int LAST_DB_VERSION = 110;
|
private final static int LAST_DB_VERSION = 111;
|
||||||
private boolean databaseMigrationInProgress;
|
private boolean databaseMigrationInProgress;
|
||||||
public boolean showClearDatabaseAlert;
|
public boolean showClearDatabaseAlert;
|
||||||
private LongSparseIntArray dialogIsForum = new LongSparseIntArray();
|
private LongSparseIntArray dialogIsForum = new LongSparseIntArray();
|
||||||
|
@ -374,6 +373,7 @@ public class MessagesStorage extends BaseController {
|
||||||
database.executeFast("CREATE TABLE stickers_v2(id INTEGER PRIMARY KEY, data BLOB, date INTEGER, hash INTEGER);").stepThis().dispose();
|
database.executeFast("CREATE TABLE stickers_v2(id INTEGER PRIMARY KEY, data BLOB, date INTEGER, hash INTEGER);").stepThis().dispose();
|
||||||
database.executeFast("CREATE TABLE stickers_featured(id INTEGER PRIMARY KEY, data BLOB, unread BLOB, date INTEGER, hash INTEGER, premium INTEGER, emoji INTEGER);").stepThis().dispose();
|
database.executeFast("CREATE TABLE stickers_featured(id INTEGER PRIMARY KEY, data BLOB, unread BLOB, date INTEGER, hash INTEGER, premium INTEGER, emoji INTEGER);").stepThis().dispose();
|
||||||
database.executeFast("CREATE TABLE stickers_dice(emoji TEXT PRIMARY KEY, data BLOB, date INTEGER);").stepThis().dispose();
|
database.executeFast("CREATE TABLE stickers_dice(emoji TEXT PRIMARY KEY, data BLOB, date INTEGER);").stepThis().dispose();
|
||||||
|
database.executeFast("CREATE TABLE stickersets(id INTEGER PRIMATE KEY, data BLOB, hash INTEGER);").stepThis().dispose();
|
||||||
database.executeFast("CREATE TABLE hashtag_recent_v2(id TEXT PRIMARY KEY, date INTEGER);").stepThis().dispose();
|
database.executeFast("CREATE TABLE hashtag_recent_v2(id TEXT PRIMARY KEY, date INTEGER);").stepThis().dispose();
|
||||||
database.executeFast("CREATE TABLE webpage_pending_v2(id INTEGER, mid INTEGER, uid INTEGER, PRIMARY KEY (id, mid, uid));").stepThis().dispose();
|
database.executeFast("CREATE TABLE webpage_pending_v2(id INTEGER, mid INTEGER, uid INTEGER, PRIMARY KEY (id, mid, uid));").stepThis().dispose();
|
||||||
database.executeFast("CREATE TABLE sent_files_v2(uid TEXT, type INTEGER, data BLOB, parent TEXT, PRIMARY KEY (uid, type))").stepThis().dispose();
|
database.executeFast("CREATE TABLE sent_files_v2(uid TEXT, type INTEGER, data BLOB, parent TEXT, PRIMARY KEY (uid, type))").stepThis().dispose();
|
||||||
|
@ -1083,6 +1083,7 @@ public class MessagesStorage extends BaseController {
|
||||||
database.executeFast("DELETE FROM attach_menu_bots").stepThis().dispose();
|
database.executeFast("DELETE FROM attach_menu_bots").stepThis().dispose();
|
||||||
database.executeFast("DELETE FROM animated_emoji").stepThis().dispose();
|
database.executeFast("DELETE FROM animated_emoji").stepThis().dispose();
|
||||||
database.executeFast("DELETE FROM stickers_v2").stepThis().dispose();
|
database.executeFast("DELETE FROM stickers_v2").stepThis().dispose();
|
||||||
|
database.executeFast("DELETE FROM stickersets").stepThis().dispose();
|
||||||
database.executeFast("DELETE FROM messages_holes_topics").stepThis().dispose();
|
database.executeFast("DELETE FROM messages_holes_topics").stepThis().dispose();
|
||||||
database.executeFast("DELETE FROM messages_topics").stepThis().dispose();
|
database.executeFast("DELETE FROM messages_topics").stepThis().dispose();
|
||||||
database.executeFast("DELETE FROM topics").stepThis().dispose();
|
database.executeFast("DELETE FROM topics").stepThis().dispose();
|
||||||
|
@ -9738,12 +9739,23 @@ public class MessagesStorage extends BaseController {
|
||||||
if (unreadCount == 0) {
|
if (unreadCount == 0) {
|
||||||
unreadMentionsCount = 0;
|
unreadMentionsCount = 0;
|
||||||
} else {
|
} else {
|
||||||
cursor = database.queryFinalized(String.format(Locale.US, "SELECT count(mid) FROM messages_topics WHERE uid = %d AND topic_id = %d AND mid > %d AND read_state < 2 AND out = 0", -chatId, mid, readMaxId));
|
cursor = database.queryFinalized(String.format(Locale.US, "SELECT count(mid) FROM messages_topics WHERE uid = %d AND topic_id = %d AND mid > %d AND read_state IN(0, 1) AND out = 0", -chatId, mid, readMaxId));
|
||||||
if (cursor.next()) {
|
if (cursor.next()) {
|
||||||
unreadMentionsCount = cursor.intValue(0);
|
unreadMentionsCount = cursor.intValue(0);
|
||||||
}
|
}
|
||||||
cursor.dispose();
|
cursor.dispose();
|
||||||
cursor = null;
|
cursor = null;
|
||||||
|
|
||||||
|
int currentUnreadMentions = 0;
|
||||||
|
cursor = database.queryFinalized(String.format(Locale.US, "SELECT unread_mentions FROM topics WHERE did = %d AND topic_id = %d", -chatId, mid));
|
||||||
|
if (cursor.next()) {
|
||||||
|
currentUnreadMentions = cursor.intValue(0);
|
||||||
|
}
|
||||||
|
cursor.dispose();
|
||||||
|
cursor = null;
|
||||||
|
if (unreadMentionsCount > currentUnreadMentions) {
|
||||||
|
unreadMentionsCount = currentUnreadMentions;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else if (unreadCount == 0) {
|
} else if (unreadCount == 0) {
|
||||||
unreadMentionsCount = 0;
|
unreadMentionsCount = 0;
|
||||||
|
|
|
@ -12,9 +12,12 @@ import android.os.SystemClock;
|
||||||
import android.util.SparseArray;
|
import android.util.SparseArray;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
|
|
||||||
|
import androidx.annotation.NonNull;
|
||||||
|
import androidx.annotation.Nullable;
|
||||||
import androidx.annotation.UiThread;
|
import androidx.annotation.UiThread;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
|
||||||
|
@ -572,7 +575,7 @@ public class NotificationCenter {
|
||||||
}
|
}
|
||||||
ArrayList<NotificationCenterDelegate> objects = observers.get(id);
|
ArrayList<NotificationCenterDelegate> objects = observers.get(id);
|
||||||
if (objects == null) {
|
if (objects == null) {
|
||||||
observers.put(id, (objects = new ArrayList<>()));
|
observers.put(id, (objects = createArrayForId(id)));
|
||||||
}
|
}
|
||||||
if (objects.contains(observer)) {
|
if (objects.contains(observer)) {
|
||||||
return;
|
return;
|
||||||
|
@ -580,6 +583,15 @@ public class NotificationCenter {
|
||||||
objects.add(observer);
|
objects.add(observer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private ArrayList<NotificationCenterDelegate> createArrayForId(int id) {
|
||||||
|
// this notifications often add/remove
|
||||||
|
// UniqArrayList for fast contains method check
|
||||||
|
if (id == didReplacedPhotoInMemCache || id == stopAllHeavyOperations || id == startAllHeavyOperations) {
|
||||||
|
return new UniqArrayList<>();
|
||||||
|
}
|
||||||
|
return new ArrayList<>();
|
||||||
|
}
|
||||||
|
|
||||||
public void removeObserver(NotificationCenterDelegate observer, int id) {
|
public void removeObserver(NotificationCenterDelegate observer, int id) {
|
||||||
if (BuildVars.DEBUG_VERSION) {
|
if (BuildVars.DEBUG_VERSION) {
|
||||||
if (Thread.currentThread() != ApplicationLoader.applicationHandler.getLooper().getThread()) {
|
if (Thread.currentThread() != ApplicationLoader.applicationHandler.getLooper().getThread()) {
|
||||||
|
@ -677,4 +689,72 @@ public class NotificationCenter {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private class UniqArrayList<T> extends ArrayList<T> {
|
||||||
|
HashSet<T> set = new HashSet<>();
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean add(T t) {
|
||||||
|
if (set.add(t)) {
|
||||||
|
return super.add(t);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void add(int index, T element) {
|
||||||
|
if (set.add(element)) {
|
||||||
|
super.add(index, element);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean addAll(@NonNull Collection<? extends T> c) {
|
||||||
|
boolean modified = false;
|
||||||
|
for (T t : c) {
|
||||||
|
if (add(t)) {
|
||||||
|
modified = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return modified;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean addAll(int index, @NonNull Collection<? extends T> c) {
|
||||||
|
throw new UnsupportedOperationException();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public T remove(int index) {
|
||||||
|
T t = super.remove(index);
|
||||||
|
if (t != null) {
|
||||||
|
set.remove(t);
|
||||||
|
}
|
||||||
|
return t;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean remove(@Nullable Object o) {
|
||||||
|
if (set.remove(0)) {
|
||||||
|
return super.remove(o);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean removeAll(@NonNull Collection<?> c) {
|
||||||
|
throw new UnsupportedOperationException();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean contains(@Nullable Object o) {
|
||||||
|
return set.contains(o);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void clear() {
|
||||||
|
set.clear();
|
||||||
|
super.clear();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -7130,13 +7130,25 @@ public class SendMessagesHelper extends BaseController implements NotificationCe
|
||||||
|
|
||||||
@UiThread
|
@UiThread
|
||||||
public static void prepareSendingText(AccountInstance accountInstance, String text, long dialogId, boolean notify, int scheduleDate) {
|
public static void prepareSendingText(AccountInstance accountInstance, String text, long dialogId, boolean notify, int scheduleDate) {
|
||||||
|
prepareSendingText(accountInstance, text, dialogId, 0, notify, scheduleDate);
|
||||||
|
}
|
||||||
|
|
||||||
|
@UiThread
|
||||||
|
public static void prepareSendingText(AccountInstance accountInstance, String text, long dialogId, int topicId, boolean notify, int scheduleDate) {
|
||||||
accountInstance.getMessagesStorage().getStorageQueue().postRunnable(() -> Utilities.stageQueue.postRunnable(() -> AndroidUtilities.runOnUIThread(() -> {
|
accountInstance.getMessagesStorage().getStorageQueue().postRunnable(() -> Utilities.stageQueue.postRunnable(() -> AndroidUtilities.runOnUIThread(() -> {
|
||||||
String textFinal = getTrimmedString(text);
|
String textFinal = getTrimmedString(text);
|
||||||
if (textFinal.length() != 0) {
|
if (textFinal.length() != 0) {
|
||||||
int count = (int) Math.ceil(textFinal.length() / 4096.0f);
|
int count = (int) Math.ceil(textFinal.length() / 4096.0f);
|
||||||
|
MessageObject replyToMsg = null;
|
||||||
|
if (topicId != 0) {
|
||||||
|
TLRPC.TL_forumTopic topic = accountInstance.getMessagesController().getTopicsController().findTopic(-dialogId, topicId);
|
||||||
|
if (topic != null && topic.topicStartMessage != null) {
|
||||||
|
replyToMsg = new MessageObject(accountInstance.getCurrentAccount(), topic.topicStartMessage, false, false);
|
||||||
|
}
|
||||||
|
}
|
||||||
for (int a = 0; a < count; a++) {
|
for (int a = 0; a < count; a++) {
|
||||||
String mess = textFinal.substring(a * 4096, Math.min((a + 1) * 4096, textFinal.length()));
|
String mess = textFinal.substring(a * 4096, Math.min((a + 1) * 4096, textFinal.length()));
|
||||||
accountInstance.getSendMessagesHelper().sendMessage(mess, dialogId, null, null, null, true, null, null, null, notify, scheduleDate, null, false);
|
accountInstance.getSendMessagesHelper().sendMessage(mess, dialogId, replyToMsg, replyToMsg, null, true, null, null, null, notify, scheduleDate, null, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})));
|
})));
|
||||||
|
|
|
@ -11,7 +11,6 @@ package org.telegram.messenger;
|
||||||
import android.graphics.Bitmap;
|
import android.graphics.Bitmap;
|
||||||
import android.graphics.Canvas;
|
import android.graphics.Canvas;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
import android.util.Log;
|
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
|
|
||||||
import org.telegram.tgnet.AbstractSerializedData;
|
import org.telegram.tgnet.AbstractSerializedData;
|
||||||
|
@ -149,6 +148,7 @@ public class VideoEditedInfo {
|
||||||
viewWidth = data.readInt32(false);
|
viewWidth = data.readInt32(false);
|
||||||
viewHeight = data.readInt32(false);
|
viewHeight = data.readInt32(false);
|
||||||
textAlign = data.readInt32(false);
|
textAlign = data.readInt32(false);
|
||||||
|
textTypeface = PaintTypeface.find(data.readString(false));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void serializeTo(SerializedData data) {
|
private void serializeTo(SerializedData data) {
|
||||||
|
@ -169,6 +169,7 @@ public class VideoEditedInfo {
|
||||||
data.writeInt32(viewWidth);
|
data.writeInt32(viewWidth);
|
||||||
data.writeInt32(viewHeight);
|
data.writeInt32(viewHeight);
|
||||||
data.writeInt32(textAlign);
|
data.writeInt32(textAlign);
|
||||||
|
data.writeString(textTypeface == null ? "" : textTypeface.getKey());
|
||||||
}
|
}
|
||||||
|
|
||||||
public MediaEntity copy() {
|
public MediaEntity copy() {
|
||||||
|
@ -192,6 +193,7 @@ public class VideoEditedInfo {
|
||||||
entity.textViewX = textViewX;
|
entity.textViewX = textViewX;
|
||||||
entity.textViewY = textViewY;
|
entity.textViewY = textViewY;
|
||||||
entity.textAlign = textAlign;
|
entity.textAlign = textAlign;
|
||||||
|
entity.textTypeface = textTypeface;
|
||||||
return entity;
|
return entity;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -48,7 +48,7 @@ public class BitmapsCache {
|
||||||
static volatile boolean cleanupScheduled;
|
static volatile boolean cleanupScheduled;
|
||||||
byte[] bufferTmp;
|
byte[] bufferTmp;
|
||||||
|
|
||||||
private final static int N = Utilities.clamp(Runtime.getRuntime().availableProcessors() - 2, 8, 1);
|
private final static int N = Utilities.clamp(Runtime.getRuntime().availableProcessors() - 2, 6, 1);
|
||||||
private static ThreadPoolExecutor bitmapCompressExecutor;
|
private static ThreadPoolExecutor bitmapCompressExecutor;
|
||||||
private final Object mutex = new Object();
|
private final Object mutex = new Object();
|
||||||
private int frameIndex;
|
private int frameIndex;
|
||||||
|
|
|
@ -14,6 +14,7 @@ import android.text.TextUtils;
|
||||||
|
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
|
|
||||||
|
import org.telegram.messenger.BuildVars;
|
||||||
import org.telegram.messenger.FileLoader;
|
import org.telegram.messenger.FileLoader;
|
||||||
import org.telegram.messenger.FileLog;
|
import org.telegram.messenger.FileLog;
|
||||||
import org.telegram.messenger.ImageLoader;
|
import org.telegram.messenger.ImageLoader;
|
||||||
|
@ -25466,7 +25467,7 @@ public class TLRPC {
|
||||||
ttl = stream.readInt32(exception);
|
ttl = stream.readInt32(exception);
|
||||||
message = stream.readString(exception);
|
message = stream.readString(exception);
|
||||||
if ((flags & 512) != 0) {
|
if ((flags & 512) != 0) {
|
||||||
media = DecryptedMessageMedia.TLdeserialize(stream, stream.readInt32(exception), exception);
|
media = DecryptedMessageMedia.TLdeserialize(stream, stream.readInt32(exception), exception || BuildVars.DEBUG_PRIVATE_VERSION);
|
||||||
}
|
}
|
||||||
if ((flags & 128) != 0) {
|
if ((flags & 128) != 0) {
|
||||||
int magic = stream.readInt32(exception);
|
int magic = stream.readInt32(exception);
|
||||||
|
@ -25478,7 +25479,7 @@ public class TLRPC {
|
||||||
}
|
}
|
||||||
int count = stream.readInt32(exception);
|
int count = stream.readInt32(exception);
|
||||||
for (int a = 0; a < count; a++) {
|
for (int a = 0; a < count; a++) {
|
||||||
MessageEntity object = MessageEntity.TLdeserialize(stream, stream.readInt32(exception), exception);
|
MessageEntity object = MessageEntity.TLdeserialize(stream, stream.readInt32(exception), exception || BuildVars.DEBUG_PRIVATE_VERSION);
|
||||||
if (object == null) {
|
if (object == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -40018,9 +40019,12 @@ public class TLRPC {
|
||||||
case 0x89f5c4a:
|
case 0x89f5c4a:
|
||||||
result = new TL_decryptedMessageMediaEmpty();
|
result = new TL_decryptedMessageMediaEmpty();
|
||||||
break;
|
break;
|
||||||
case 0x7afe8ae2:
|
case 0x6abd9782:
|
||||||
result = new TL_decryptedMessageMediaDocument();
|
result = new TL_decryptedMessageMediaDocument();
|
||||||
break;
|
break;
|
||||||
|
case 0x7afe8ae2:
|
||||||
|
result = new TL_decryptedMessageMediaDocument_layer101();
|
||||||
|
break;
|
||||||
case 0xe50511d8:
|
case 0xe50511d8:
|
||||||
result = new TL_decryptedMessageMediaWebPage();
|
result = new TL_decryptedMessageMediaWebPage();
|
||||||
break;
|
break;
|
||||||
|
@ -40130,6 +40134,56 @@ public class TLRPC {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class TL_decryptedMessageMediaDocument extends DecryptedMessageMedia {
|
public static class TL_decryptedMessageMediaDocument extends DecryptedMessageMedia {
|
||||||
|
public static int constructor = 0x6abd9782;
|
||||||
|
|
||||||
|
public byte[] thumb;
|
||||||
|
|
||||||
|
public void readParams(AbstractSerializedData stream, boolean exception) {
|
||||||
|
thumb = stream.readByteArray(exception);
|
||||||
|
thumb_w = stream.readInt32(exception);
|
||||||
|
thumb_h = stream.readInt32(exception);
|
||||||
|
mime_type = stream.readString(exception);
|
||||||
|
size = stream.readInt64(exception);
|
||||||
|
key = stream.readByteArray(exception);
|
||||||
|
iv = stream.readByteArray(exception);
|
||||||
|
int magic = stream.readInt32(exception);
|
||||||
|
if (magic != 0x1cb5c415) {
|
||||||
|
if (exception) {
|
||||||
|
throw new RuntimeException(String.format("wrong Vector magic, got %x", magic));
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
int count = stream.readInt32(exception);
|
||||||
|
for (int a = 0; a < count; a++) {
|
||||||
|
DocumentAttribute object = DocumentAttribute.TLdeserialize(stream, stream.readInt32(exception), exception);
|
||||||
|
if (object == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
attributes.add(object);
|
||||||
|
}
|
||||||
|
caption = stream.readString(exception);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void serializeToStream(AbstractSerializedData stream) {
|
||||||
|
stream.writeInt32(constructor);
|
||||||
|
stream.writeByteArray(thumb);
|
||||||
|
stream.writeInt32(thumb_w);
|
||||||
|
stream.writeInt32(thumb_h);
|
||||||
|
stream.writeString(mime_type);
|
||||||
|
stream.writeInt64(size);
|
||||||
|
stream.writeByteArray(key);
|
||||||
|
stream.writeByteArray(iv);
|
||||||
|
stream.writeInt32(0x1cb5c415);
|
||||||
|
int count = attributes.size();
|
||||||
|
stream.writeInt32(count);
|
||||||
|
for (int a = 0; a < count; a++) {
|
||||||
|
attributes.get(a).serializeToStream(stream);
|
||||||
|
}
|
||||||
|
stream.writeString(caption);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class TL_decryptedMessageMediaDocument_layer101 extends TL_decryptedMessageMediaDocument {
|
||||||
public static int constructor = 0x7afe8ae2;
|
public static int constructor = 0x7afe8ae2;
|
||||||
|
|
||||||
public byte[] thumb;
|
public byte[] thumb;
|
||||||
|
@ -53517,9 +53571,10 @@ public class TLRPC {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class TL_messages_getStickerSet extends TLObject {
|
public static class TL_messages_getStickerSet extends TLObject {
|
||||||
public static int constructor = 0x2619a90e;
|
public static int constructor = 0xc8a0ec74;
|
||||||
|
|
||||||
public InputStickerSet stickerset;
|
public InputStickerSet stickerset;
|
||||||
|
public int hash;
|
||||||
|
|
||||||
public TLObject deserializeResponse(AbstractSerializedData stream, int constructor, boolean exception) {
|
public TLObject deserializeResponse(AbstractSerializedData stream, int constructor, boolean exception) {
|
||||||
return TL_messages_stickerSet.TLdeserialize(stream, constructor, exception);
|
return TL_messages_stickerSet.TLdeserialize(stream, constructor, exception);
|
||||||
|
@ -53528,6 +53583,7 @@ public class TLRPC {
|
||||||
public void serializeToStream(AbstractSerializedData stream) {
|
public void serializeToStream(AbstractSerializedData stream) {
|
||||||
stream.writeInt32(constructor);
|
stream.writeInt32(constructor);
|
||||||
stickerset.serializeToStream(stream);
|
stickerset.serializeToStream(stream);
|
||||||
|
stream.writeInt32(hash);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5893,7 +5893,7 @@ public class Theme {
|
||||||
if (monthOfYear == 0 && dayOfMonth == 1 && hour <= 23) {
|
if (monthOfYear == 0 && dayOfMonth == 1 && hour <= 23) {
|
||||||
canStartHolidayAnimation = true;
|
canStartHolidayAnimation = true;
|
||||||
} else {
|
} else {
|
||||||
canStartHolidayAnimation = BuildVars.DEBUG_VERSION;//false;
|
canStartHolidayAnimation = false;
|
||||||
}
|
}
|
||||||
if (dialogs_holidayDrawable == null) {
|
if (dialogs_holidayDrawable == null) {
|
||||||
if (monthOfYear == 11 && dayOfMonth >= (BuildVars.DEBUG_PRIVATE_VERSION ? 29 : 31) && dayOfMonth <= 31 || monthOfYear == 0 && dayOfMonth == 1) {
|
if (monthOfYear == 11 && dayOfMonth >= (BuildVars.DEBUG_PRIVATE_VERSION ? 29 : 31) && dayOfMonth <= 31 || monthOfYear == 0 && dayOfMonth == 1) {
|
||||||
|
|
|
@ -9854,7 +9854,7 @@ public class ChatMessageCell extends BaseCell implements SeekBar.SeekBarDelegate
|
||||||
canvas.save();
|
canvas.save();
|
||||||
canvas.translate(linkX + AndroidUtilities.dp(10) + descriptionX, descriptionY);
|
canvas.translate(linkX + AndroidUtilities.dp(10) + descriptionX, descriptionY);
|
||||||
descriptionLayout.draw(canvas);
|
descriptionLayout.draw(canvas);
|
||||||
AnimatedEmojiSpan.drawAnimatedEmojis(canvas, descriptionLayout, animatedEmojiDescriptionStack, 0, null, 0, 0, 0, 1f);
|
AnimatedEmojiSpan.drawAnimatedEmojis(canvas, descriptionLayout, animatedEmojiDescriptionStack, 0, null, 0, 0, 0, 1f, Theme.chat_animatedEmojiTextColorFilter);
|
||||||
canvas.restore();
|
canvas.restore();
|
||||||
}
|
}
|
||||||
drawTime = true;
|
drawTime = true;
|
||||||
|
@ -10348,7 +10348,7 @@ public class ChatMessageCell extends BaseCell implements SeekBar.SeekBarDelegate
|
||||||
delegate.getTextSelectionHelper().drawDescription(currentMessageObject.isOutOwner(), descriptionLayout, canvas);
|
delegate.getTextSelectionHelper().drawDescription(currentMessageObject.isOutOwner(), descriptionLayout, canvas);
|
||||||
}
|
}
|
||||||
descriptionLayout.draw(canvas);
|
descriptionLayout.draw(canvas);
|
||||||
AnimatedEmojiSpan.drawAnimatedEmojis(canvas, descriptionLayout, animatedEmojiDescriptionStack, 0, null, 0, 0, 0, 1f);
|
AnimatedEmojiSpan.drawAnimatedEmojis(canvas, descriptionLayout, animatedEmojiDescriptionStack, 0, null, 0, 0, 0, 1f, Theme.chat_animatedEmojiTextColorFilter);
|
||||||
canvas.restore();
|
canvas.restore();
|
||||||
linkPreviewY += descriptionLayout.getLineBottom(descriptionLayout.getLineCount() - 1);
|
linkPreviewY += descriptionLayout.getLineBottom(descriptionLayout.getLineCount() - 1);
|
||||||
}
|
}
|
||||||
|
@ -13767,7 +13767,7 @@ public class ChatMessageCell extends BaseCell implements SeekBar.SeekBarDelegate
|
||||||
if (transitionParams.messageEntering) {
|
if (transitionParams.messageEntering) {
|
||||||
top = bottom = 0;
|
top = bottom = 0;
|
||||||
}
|
}
|
||||||
AnimatedEmojiSpan.drawAnimatedEmojis(canvas, block.textLayout, stack, 0, block.spoilers, top, bottom, drawingYOffset, alpha);
|
AnimatedEmojiSpan.drawAnimatedEmojis(canvas, block.textLayout, stack, 0, block.spoilers, top, bottom, drawingYOffset, alpha, Theme.chat_animatedEmojiTextColorFilter);
|
||||||
canvas.restore();
|
canvas.restore();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -13811,7 +13811,7 @@ public class ChatMessageCell extends BaseCell implements SeekBar.SeekBarDelegate
|
||||||
|
|
||||||
canvas.translate(captionX, captionY);
|
canvas.translate(captionX, captionY);
|
||||||
try {
|
try {
|
||||||
AnimatedEmojiSpan.drawAnimatedEmojis(canvas, layout, stack, 0, captionSpoilers, 0, 0, captionY, renderingAlpha);
|
AnimatedEmojiSpan.drawAnimatedEmojis(canvas, layout, stack, 0, captionSpoilers, 0, 0, captionY, renderingAlpha, Theme.chat_animatedEmojiTextColorFilter);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
FileLog.e(e);
|
FileLog.e(e);
|
||||||
}
|
}
|
||||||
|
@ -14692,7 +14692,7 @@ public class ChatMessageCell extends BaseCell implements SeekBar.SeekBarDelegate
|
||||||
canvas.translate(forwardNameX, replyStartY + Theme.chat_replyNamePaint.getTextSize() + AndroidUtilities.dp(5));
|
canvas.translate(forwardNameX, replyStartY + Theme.chat_replyNamePaint.getTextSize() + AndroidUtilities.dp(5));
|
||||||
int spoilersColor = currentMessageObject.isOut() && !ChatObject.isChannelAndNotMegaGroup(currentMessageObject.getChatId(), currentAccount) ? getThemedColor(Theme.key_chat_outTimeText) : replyTextLayout.getPaint().getColor();
|
int spoilersColor = currentMessageObject.isOut() && !ChatObject.isChannelAndNotMegaGroup(currentMessageObject.getChatId(), currentAccount) ? getThemedColor(Theme.key_chat_outTimeText) : replyTextLayout.getPaint().getColor();
|
||||||
SpoilerEffect.renderWithRipple(this, invalidateSpoilersParent, spoilersColor, -AndroidUtilities.dp(2), spoilersPatchedReplyTextLayout, replyTextLayout, replySpoilers, canvas, false);
|
SpoilerEffect.renderWithRipple(this, invalidateSpoilersParent, spoilersColor, -AndroidUtilities.dp(2), spoilersPatchedReplyTextLayout, replyTextLayout, replySpoilers, canvas, false);
|
||||||
AnimatedEmojiSpan.drawAnimatedEmojis(canvas, replyTextLayout, animatedEmojiReplyStack, 0, replySpoilers, 0, 0, 0, alpha);
|
AnimatedEmojiSpan.drawAnimatedEmojis(canvas, replyTextLayout, animatedEmojiReplyStack, 0, replySpoilers, 0, 0, 0, alpha, Theme.chat_animatedEmojiTextColorFilter);
|
||||||
canvas.restore();
|
canvas.restore();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -855,7 +855,7 @@ public class DialogCell extends BaseCell {
|
||||||
}
|
}
|
||||||
if (isDialogCell) {
|
if (isDialogCell) {
|
||||||
boolean needUpdate = updateHelper.update();
|
boolean needUpdate = updateHelper.update();
|
||||||
if (!needUpdate && currentDialogFolderId == 0) {
|
if (!needUpdate && currentDialogFolderId == 0 && encryptedChat == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,6 +33,7 @@ import org.telegram.messenger.ImageLocation;
|
||||||
import org.telegram.messenger.LocaleController;
|
import org.telegram.messenger.LocaleController;
|
||||||
import org.telegram.messenger.MediaDataController;
|
import org.telegram.messenger.MediaDataController;
|
||||||
import org.telegram.messenger.MessageObject;
|
import org.telegram.messenger.MessageObject;
|
||||||
|
import org.telegram.messenger.NotificationCenter;
|
||||||
import org.telegram.messenger.R;
|
import org.telegram.messenger.R;
|
||||||
import org.telegram.messenger.SvgHelper;
|
import org.telegram.messenger.SvgHelper;
|
||||||
import org.telegram.messenger.UserConfig;
|
import org.telegram.messenger.UserConfig;
|
||||||
|
@ -49,7 +50,7 @@ import org.telegram.ui.Components.RecyclerListView;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class FeaturedStickerSetCell2 extends FrameLayout {
|
public class FeaturedStickerSetCell2 extends FrameLayout implements NotificationCenter.NotificationCenterDelegate {
|
||||||
|
|
||||||
private final int currentAccount = UserConfig.selectedAccount;
|
private final int currentAccount = UserConfig.selectedAccount;
|
||||||
|
|
||||||
|
@ -67,6 +68,11 @@ public class FeaturedStickerSetCell2 extends FrameLayout {
|
||||||
private boolean needDivider;
|
private boolean needDivider;
|
||||||
private final Theme.ResourcesProvider resourcesProvider;
|
private final Theme.ResourcesProvider resourcesProvider;
|
||||||
|
|
||||||
|
private boolean bindedObserver;
|
||||||
|
private Long waitingForStickerSetId;
|
||||||
|
private boolean unread;
|
||||||
|
private boolean forceInstalled;
|
||||||
|
|
||||||
public FeaturedStickerSetCell2(Context context, Theme.ResourcesProvider resourcesProvider) {
|
public FeaturedStickerSetCell2(Context context, Theme.ResourcesProvider resourcesProvider) {
|
||||||
super(context);
|
super(context);
|
||||||
this.resourcesProvider = resourcesProvider;
|
this.resourcesProvider = resourcesProvider;
|
||||||
|
@ -162,7 +168,7 @@ public class FeaturedStickerSetCell2 extends FrameLayout {
|
||||||
setWillNotDraw(!needDivider);
|
setWillNotDraw(!needDivider);
|
||||||
|
|
||||||
textView.setText(stickersSet.set.title);
|
textView.setText(stickersSet.set.title);
|
||||||
if (unread) {
|
if (this.unread = unread) {
|
||||||
Drawable drawable = new Drawable() {
|
Drawable drawable = new Drawable() {
|
||||||
|
|
||||||
Paint paint = new Paint(Paint.ANTI_ALIAS_FLAG);
|
Paint paint = new Paint(Paint.ANTI_ALIAS_FLAG);
|
||||||
|
@ -206,16 +212,35 @@ public class FeaturedStickerSetCell2 extends FrameLayout {
|
||||||
valueTextView.setText(LocaleController.formatPluralString(set.set.emojis ? "EmojiCount" : "Stickers", set.set.count));
|
valueTextView.setText(LocaleController.formatPluralString(set.set.emojis ? "EmojiCount" : "Stickers", set.set.count));
|
||||||
|
|
||||||
TLRPC.Document sticker;
|
TLRPC.Document sticker;
|
||||||
if (set.cover != null) {
|
if (set instanceof TLRPC.TL_stickerSetNoCovered && set.set != null) {
|
||||||
|
sticker = null;
|
||||||
|
waitingForStickerSetId = set.set.id;
|
||||||
|
if (!bindedObserver) {
|
||||||
|
NotificationCenter.getInstance(currentAccount).addObserver(this, NotificationCenter.groupStickersDidLoad);
|
||||||
|
bindedObserver = true;
|
||||||
|
}
|
||||||
|
TLRPC.TL_messages_stickerSet fullSet = MediaDataController.getInstance(currentAccount).getStickerSet(MediaDataController.getInputStickerSet(set.set), set.set.hash, false);
|
||||||
|
if (fullSet != null && fullSet.documents != null && !fullSet.documents.isEmpty()) {
|
||||||
|
sticker = fullSet.documents.get(0);
|
||||||
|
for (int i = 0; i < fullSet.documents.size(); ++i) {
|
||||||
|
if (fullSet.documents.get(i).id == set.set.thumb_document_id) {
|
||||||
|
sticker = fullSet.documents.get(i);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (set.cover != null) {
|
||||||
sticker = set.cover;
|
sticker = set.cover;
|
||||||
} else if (!set.covers.isEmpty()) {
|
} else if (!set.covers.isEmpty()) {
|
||||||
sticker = set.covers.get(0);
|
sticker = set.covers.get(0);
|
||||||
|
if (set.set != null) {
|
||||||
for (int i = 0; i < set.covers.size(); ++i) {
|
for (int i = 0; i < set.covers.size(); ++i) {
|
||||||
if (set.covers.get(i).id == set.set.thumb_document_id) {
|
if (set.covers.get(i).id == set.set.thumb_document_id) {
|
||||||
sticker = set.covers.get(i);
|
sticker = set.covers.get(i);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
} else if ((set instanceof TLRPC.TL_stickerSetFullCovered && !((TLRPC.TL_stickerSetFullCovered) set).documents.isEmpty())) {
|
} else if ((set instanceof TLRPC.TL_stickerSetFullCovered && !((TLRPC.TL_stickerSetFullCovered) set).documents.isEmpty())) {
|
||||||
ArrayList<TLRPC.Document> documents = ((TLRPC.TL_stickerSetFullCovered) set).documents;
|
ArrayList<TLRPC.Document> documents = ((TLRPC.TL_stickerSetFullCovered) set).documents;
|
||||||
sticker = documents.get(0);
|
sticker = documents.get(0);
|
||||||
|
@ -269,6 +294,7 @@ public class FeaturedStickerSetCell2 extends FrameLayout {
|
||||||
}
|
}
|
||||||
|
|
||||||
addButton.setVisibility(VISIBLE);
|
addButton.setVisibility(VISIBLE);
|
||||||
|
this.forceInstalled = forceInstalled;
|
||||||
isInstalled = forceInstalled || MediaDataController.getInstance(currentAccount).isStickerPackInstalled(set.set.id);
|
isInstalled = forceInstalled || MediaDataController.getInstance(currentAccount).isStickerPackInstalled(set.set.id);
|
||||||
isLocked = !UserConfig.getInstance(currentAccount).isPremium() && MessageObject.isPremiumEmojiPack(set);
|
isLocked = !UserConfig.getInstance(currentAccount).isPremium() && MessageObject.isPremiumEmojiPack(set);
|
||||||
if (animated) {
|
if (animated) {
|
||||||
|
@ -403,4 +429,26 @@ public class FeaturedStickerSetCell2 extends FrameLayout {
|
||||||
Integer color = resourcesProvider != null ? resourcesProvider.getColor(key) : null;
|
Integer color = resourcesProvider != null ? resourcesProvider.getColor(key) : null;
|
||||||
return color != null ? color : Theme.getColor(key);
|
return color != null ? color : Theme.getColor(key);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onDetachedFromWindow() {
|
||||||
|
super.onDetachedFromWindow();
|
||||||
|
if (bindedObserver) {
|
||||||
|
NotificationCenter.getInstance(currentAccount).removeObserver(this, NotificationCenter.groupStickersDidLoad);
|
||||||
|
bindedObserver = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void didReceivedNotification(int id, int account, Object... args) {
|
||||||
|
if (id == NotificationCenter.groupStickersDidLoad) {
|
||||||
|
long setId = (long) args[0];
|
||||||
|
if (waitingForStickerSetId != null && waitingForStickerSetId == setId) {
|
||||||
|
waitingForStickerSetId = null;
|
||||||
|
TLRPC.TL_stickerSetNoCovered setNoCovered = new TLRPC.TL_stickerSetNoCovered();
|
||||||
|
setNoCovered.set = ((TLRPC.TL_messages_stickerSet) args[1]).set;
|
||||||
|
setStickersSet(setNoCovered, needDivider, unread, forceInstalled, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -23643,7 +23643,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
|
||||||
didPressMessageUrl(link, false, selectedObject, v instanceof ChatMessageCell ? (ChatMessageCell) v : null);
|
didPressMessageUrl(link, false, selectedObject, v instanceof ChatMessageCell ? (ChatMessageCell) v : null);
|
||||||
return true;
|
return true;
|
||||||
};
|
};
|
||||||
TLRPC.InputPeer inputPeer = selectedObject != null && (selectedObject.isPoll() || selectedObject.isVoiceTranscriptionOpen()) ? null : getMessagesController().getInputPeer(dialog_id);
|
TLRPC.InputPeer inputPeer = selectedObject != null && (selectedObject.isPoll() || selectedObject.isVoiceTranscriptionOpen() || selectedObject.isSponsored()) ? null : getMessagesController().getInputPeer(dialog_id);
|
||||||
if (LanguageDetector.hasSupport()) {
|
if (LanguageDetector.hasSupport()) {
|
||||||
final String[] fromLang = {null};
|
final String[] fromLang = {null};
|
||||||
cell.setVisibility(View.GONE);
|
cell.setVisibility(View.GONE);
|
||||||
|
|
|
@ -351,7 +351,7 @@ public final class BulletinFactory {
|
||||||
if (loadingSpan != null && bulletin.getLayout() instanceof Bulletin.LoadingLottieLayout) {
|
if (loadingSpan != null && bulletin.getLayout() instanceof Bulletin.LoadingLottieLayout) {
|
||||||
loadingSpan.setView(((Bulletin.LoadingLottieLayout) bulletin.getLayout()).textLoadingView);
|
loadingSpan.setView(((Bulletin.LoadingLottieLayout) bulletin.getLayout()).textLoadingView);
|
||||||
}
|
}
|
||||||
MediaDataController.getInstance(UserConfig.selectedAccount).getStickerSet(inputStickerSet, false, set -> {
|
MediaDataController.getInstance(UserConfig.selectedAccount).getStickerSet(inputStickerSet, null, false, set -> {
|
||||||
CharSequence message;
|
CharSequence message;
|
||||||
if (set != null && set.set != null) {
|
if (set != null && set.set != null) {
|
||||||
if (inTopic) {
|
if (inTopic) {
|
||||||
|
|
|
@ -183,6 +183,9 @@ public class DrawingInBackgroundThreadDrawable implements NotificationCenter.Not
|
||||||
}
|
}
|
||||||
|
|
||||||
public void onAttachToWindow() {
|
public void onAttachToWindow() {
|
||||||
|
if (attachedToWindow) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
attachedToWindow = true;
|
attachedToWindow = true;
|
||||||
error = false;
|
error = false;
|
||||||
currentOpenedLayerFlags = NotificationCenter.getGlobalInstance().getCurrentHeavyOperationFlags();
|
currentOpenedLayerFlags = NotificationCenter.getGlobalInstance().getCurrentHeavyOperationFlags();
|
||||||
|
@ -199,6 +202,9 @@ public class DrawingInBackgroundThreadDrawable implements NotificationCenter.Not
|
||||||
}
|
}
|
||||||
|
|
||||||
public void onDetachFromWindow() {
|
public void onDetachFromWindow() {
|
||||||
|
if (!attachedToWindow) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (!bitmapUpdating) {
|
if (!bitmapUpdating) {
|
||||||
recycleBitmaps();
|
recycleBitmaps();
|
||||||
}
|
}
|
||||||
|
|
|
@ -1571,7 +1571,7 @@ public class EmojiPacksAlert extends BottomSheet implements NotificationCenter.N
|
||||||
NotificationCenter.getInstance(currentAccount).addObserver(this, NotificationCenter.groupStickersDidLoad);
|
NotificationCenter.getInstance(currentAccount).addObserver(this, NotificationCenter.groupStickersDidLoad);
|
||||||
final boolean[] failed = new boolean[1];
|
final boolean[] failed = new boolean[1];
|
||||||
for (int i = 0; i < data.length; ++i) {
|
for (int i = 0; i < data.length; ++i) {
|
||||||
TLRPC.TL_messages_stickerSet stickerSet = MediaDataController.getInstance(currentAccount).getStickerSet(inputStickerSets.get(i), false, (set) -> {
|
TLRPC.TL_messages_stickerSet stickerSet = MediaDataController.getInstance(currentAccount).getStickerSet(inputStickerSets.get(i), null, false, (set) -> {
|
||||||
if (set == null && !failed[0]) {
|
if (set == null && !failed[0]) {
|
||||||
failed[0] = true;
|
failed[0] = true;
|
||||||
AndroidUtilities.runOnUIThread(() -> {
|
AndroidUtilities.runOnUIThread(() -> {
|
||||||
|
|
|
@ -5626,6 +5626,12 @@ public class EmojiView extends FrameLayout implements NotificationCenter.Notific
|
||||||
return stickersGridAdapter != null && stickersGridAdapter.getItemCount() > 0;
|
return stickersGridAdapter != null && stickersGridAdapter.getItemCount() > 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Runnable updateStickersLoadedDelayed = () -> {
|
||||||
|
if (emojiAdapter != null) {
|
||||||
|
emojiAdapter.notifyDataSetChanged(true);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, int account, Object... args) {
|
public void didReceivedNotification(int id, int account, Object... args) {
|
||||||
|
@ -5674,9 +5680,8 @@ public class EmojiView extends FrameLayout implements NotificationCenter.Notific
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (emojiAdapter != null) {
|
AndroidUtilities.cancelRunOnUIThread(updateStickersLoadedDelayed);
|
||||||
emojiAdapter.notifyDataSetChanged(true);
|
AndroidUtilities.runOnUIThread(updateStickersLoadedDelayed, 100);
|
||||||
}
|
|
||||||
} else if (id == NotificationCenter.emojiLoaded) {
|
} else if (id == NotificationCenter.emojiLoaded) {
|
||||||
if (stickersGridView != null) {
|
if (stickersGridView != null) {
|
||||||
int count = stickersGridView.getChildCount();
|
int count = stickersGridView.getChildCount();
|
||||||
|
@ -6662,7 +6667,7 @@ public class EmojiView extends FrameLayout implements NotificationCenter.Notific
|
||||||
if (set instanceof TLRPC.TL_stickerSetFullCovered) {
|
if (set instanceof TLRPC.TL_stickerSetFullCovered) {
|
||||||
pack.documents = ((TLRPC.TL_stickerSetFullCovered) set).documents;
|
pack.documents = ((TLRPC.TL_stickerSetFullCovered) set).documents;
|
||||||
} else if (set instanceof TLRPC.TL_stickerSetNoCovered) {
|
} else if (set instanceof TLRPC.TL_stickerSetNoCovered) {
|
||||||
TLRPC.TL_messages_stickerSet stickerSet = mediaDataController.getStickerSet(MediaDataController.getInputStickerSet(set.set), false);
|
TLRPC.TL_messages_stickerSet stickerSet = mediaDataController.getStickerSet(MediaDataController.getInputStickerSet(set.set), set.set.hash, false);
|
||||||
if (stickerSet != null) {
|
if (stickerSet != null) {
|
||||||
pack.documents = stickerSet.documents;
|
pack.documents = stickerSet.documents;
|
||||||
}
|
}
|
||||||
|
|
|
@ -146,6 +146,25 @@ public class PaintTypeface {
|
||||||
return typefaces;
|
return typefaces;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static PaintTypeface find(String key) {
|
||||||
|
if (key == null || TextUtils.isEmpty(key)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
if (typefaces == null) {
|
||||||
|
get();
|
||||||
|
}
|
||||||
|
if (typefaces == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
for (int i = 0; i < typefaces.size(); ++i) {
|
||||||
|
PaintTypeface typeface = typefaces.get(i);
|
||||||
|
if (typeface != null && TextUtils.equals(key, typeface.key)) {
|
||||||
|
return typeface;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
public static boolean fetched(Runnable runnable) {
|
public static boolean fetched(Runnable runnable) {
|
||||||
if (typefaces != null || runnable == null) {
|
if (typefaces != null || runnable == null) {
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -13,6 +13,7 @@ import android.view.WindowManager;
|
||||||
import android.widget.FrameLayout;
|
import android.widget.FrameLayout;
|
||||||
|
|
||||||
import org.telegram.messenger.AndroidUtilities;
|
import org.telegram.messenger.AndroidUtilities;
|
||||||
|
import org.telegram.messenger.FileLoader;
|
||||||
import org.telegram.messenger.ImageLocation;
|
import org.telegram.messenger.ImageLocation;
|
||||||
import org.telegram.messenger.ImageReceiver;
|
import org.telegram.messenger.ImageReceiver;
|
||||||
import org.telegram.messenger.MediaDataController;
|
import org.telegram.messenger.MediaDataController;
|
||||||
|
@ -743,6 +744,7 @@ public class ReactionsEffectOverlay {
|
||||||
|
|
||||||
public AnimationView(Context context) {
|
public AnimationView(Context context) {
|
||||||
super(context);
|
super(context);
|
||||||
|
getImageReceiver().setFileLoadingPriority(FileLoader.PRIORITY_HIGH);
|
||||||
}
|
}
|
||||||
|
|
||||||
boolean wasPlaying;
|
boolean wasPlaying;
|
||||||
|
|
|
@ -4937,7 +4937,6 @@ public class LaunchActivity extends BasePermissionsActivity implements INavigati
|
||||||
final ChatActivity fragment;
|
final ChatActivity fragment;
|
||||||
if (dids.size() <= 1) {
|
if (dids.size() <= 1) {
|
||||||
final long did = dids.get(0).dialogId;
|
final long did = dids.get(0).dialogId;
|
||||||
final int topicId = dids.get(0).topicId;
|
|
||||||
|
|
||||||
Bundle args = new Bundle();
|
Bundle args = new Bundle();
|
||||||
args.putBoolean("scrollToTopOnResume", true);
|
args.putBoolean("scrollToTopOnResume", true);
|
||||||
|
@ -5007,8 +5006,16 @@ public class LaunchActivity extends BasePermissionsActivity implements INavigati
|
||||||
String captionToSend = null;
|
String captionToSend = null;
|
||||||
for (int i = 0; i < dids.size(); i++) {
|
for (int i = 0; i < dids.size(); i++) {
|
||||||
final long did = dids.get(i).dialogId;
|
final long did = dids.get(i).dialogId;
|
||||||
|
final int topicId = dids.get(i).topicId;
|
||||||
|
|
||||||
AccountInstance accountInstance = AccountInstance.getInstance(UserConfig.selectedAccount);
|
AccountInstance accountInstance = AccountInstance.getInstance(UserConfig.selectedAccount);
|
||||||
|
MessageObject replyToMsg = null;
|
||||||
|
if (topicId != 0) {
|
||||||
|
TLRPC.TL_forumTopic topic = accountInstance.getMessagesController().getTopicsController().findTopic(-did, topicId);
|
||||||
|
if (topic != null && topic.topicStartMessage != null) {
|
||||||
|
replyToMsg = new MessageObject(accountInstance.getCurrentAccount(), topic.topicStartMessage, false, false);
|
||||||
|
}
|
||||||
|
}
|
||||||
boolean photosEditorOpened = false, videoEditorOpened = false;
|
boolean photosEditorOpened = false, videoEditorOpened = false;
|
||||||
if (fragment != null) {
|
if (fragment != null) {
|
||||||
boolean withoutAnimation = dialogsFragment == null || (videoPath != null || (photoPathsArray != null && photoPathsArray.size() > 0));
|
boolean withoutAnimation = dialogsFragment == null || (videoPath != null || (photoPathsArray != null && photoPathsArray.size() > 0));
|
||||||
|
@ -5031,7 +5038,7 @@ public class LaunchActivity extends BasePermissionsActivity implements INavigati
|
||||||
}
|
}
|
||||||
ArrayList<String> arrayList = new ArrayList<>();
|
ArrayList<String> arrayList = new ArrayList<>();
|
||||||
arrayList.add(videoPath);
|
arrayList.add(videoPath);
|
||||||
SendMessagesHelper.prepareSendingDocuments(accountInstance, arrayList, arrayList, null, captionToSend, null, did, null, null, null, null, notify, 0);
|
SendMessagesHelper.prepareSendingDocuments(accountInstance, arrayList, arrayList, null, captionToSend, null, did, replyToMsg, replyToMsg, null, null, notify, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (photoPathsArray != null && !photosEditorOpened) {
|
if (photoPathsArray != null && !photosEditorOpened) {
|
||||||
|
@ -5039,7 +5046,7 @@ public class LaunchActivity extends BasePermissionsActivity implements INavigati
|
||||||
photoPathsArray.get(0).caption = sendingText;
|
photoPathsArray.get(0).caption = sendingText;
|
||||||
sendingText = null;
|
sendingText = null;
|
||||||
}
|
}
|
||||||
SendMessagesHelper.prepareSendingMedia(accountInstance, photoPathsArray, did, null, null, null, false, false, null, notify, 0, false);
|
SendMessagesHelper.prepareSendingMedia(accountInstance, photoPathsArray, did, replyToMsg, replyToMsg, null, false, false, null, notify, 0, false);
|
||||||
}
|
}
|
||||||
if (documentsPathsArray != null || documentsUrisArray != null) {
|
if (documentsPathsArray != null || documentsUrisArray != null) {
|
||||||
if (sendingText != null && sendingText.length() <= 1024 && ((documentsPathsArray != null ? documentsPathsArray.size() : 0) + (documentsUrisArray != null ? documentsUrisArray.size() : 0)) == 1) {
|
if (sendingText != null && sendingText.length() <= 1024 && ((documentsPathsArray != null ? documentsPathsArray.size() : 0) + (documentsUrisArray != null ? documentsUrisArray.size() : 0)) == 1) {
|
||||||
|
@ -5049,16 +5056,16 @@ public class LaunchActivity extends BasePermissionsActivity implements INavigati
|
||||||
SendMessagesHelper.prepareSendingDocuments(accountInstance, documentsPathsArray, documentsOriginalPathsArray, documentsUrisArray, captionToSend, documentsMimeType, did, null, null, null, null, notify, 0);
|
SendMessagesHelper.prepareSendingDocuments(accountInstance, documentsPathsArray, documentsOriginalPathsArray, documentsUrisArray, captionToSend, documentsMimeType, did, null, null, null, null, notify, 0);
|
||||||
}
|
}
|
||||||
if (sendingText != null) {
|
if (sendingText != null) {
|
||||||
SendMessagesHelper.prepareSendingText(accountInstance, sendingText, did, true, 0);
|
SendMessagesHelper.prepareSendingText(accountInstance, sendingText, did, topicId, notify, 0);
|
||||||
}
|
}
|
||||||
if (contactsToSend != null && !contactsToSend.isEmpty()) {
|
if (contactsToSend != null && !contactsToSend.isEmpty()) {
|
||||||
for (int a = 0; a < contactsToSend.size(); a++) {
|
for (int a = 0; a < contactsToSend.size(); a++) {
|
||||||
TLRPC.User user = contactsToSend.get(a);
|
TLRPC.User user = contactsToSend.get(a);
|
||||||
SendMessagesHelper.getInstance(account).sendMessage(user, did, null, null, null, null, notify, 0);
|
SendMessagesHelper.getInstance(account).sendMessage(user, did, replyToMsg, replyToMsg, null, null, notify, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!TextUtils.isEmpty(message) && !videoEditorOpened && !photosEditorOpened) {
|
if (!TextUtils.isEmpty(message) && !videoEditorOpened && !photosEditorOpened) {
|
||||||
SendMessagesHelper.prepareSendingText(accountInstance, message.toString(), did, notify, 0);
|
SendMessagesHelper.prepareSendingText(accountInstance, message.toString(), did, topicId, notify, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -6618,11 +6625,15 @@ public class LaunchActivity extends BasePermissionsActivity implements INavigati
|
||||||
if (actionBarLayout != null) {
|
if (actionBarLayout != null) {
|
||||||
actionBarLayout.onLowMemory();
|
actionBarLayout.onLowMemory();
|
||||||
if (AndroidUtilities.isTablet()) {
|
if (AndroidUtilities.isTablet()) {
|
||||||
|
if (rightActionBarLayout != null) {
|
||||||
rightActionBarLayout.onLowMemory();
|
rightActionBarLayout.onLowMemory();
|
||||||
|
}
|
||||||
|
if (layersActionBarLayout != null) {
|
||||||
layersActionBarLayout.onLowMemory();
|
layersActionBarLayout.onLowMemory();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onActionModeStarted(ActionMode mode) {
|
public void onActionModeStarted(ActionMode mode) {
|
||||||
|
|
|
@ -633,7 +633,7 @@ public class NewContactBottomSheet extends BottomSheet implements AdapterView.On
|
||||||
}
|
}
|
||||||
|
|
||||||
private void doOnDone() {
|
private void doOnDone() {
|
||||||
if (donePressed) {
|
if (donePressed || parentFragment == null || parentFragment.getParentActivity() == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (firstNameField.getEditText().length() == 0) {
|
if (firstNameField.getEditText().length() == 0) {
|
||||||
|
|
|
@ -731,7 +731,7 @@ public class PremiumPreviewFragment extends BaseFragment implements Notification
|
||||||
|
|
||||||
BillingController.getInstance().addResultListener(BillingController.PREMIUM_PRODUCT_ID, billingResult -> {
|
BillingController.getInstance().addResultListener(BillingController.PREMIUM_PRODUCT_ID, billingResult -> {
|
||||||
if (billingResult.getResponseCode() == BillingClient.BillingResponseCode.OK) {
|
if (billingResult.getResponseCode() == BillingClient.BillingResponseCode.OK) {
|
||||||
onSuccess.run();
|
AndroidUtilities.runOnUIThread(onSuccess);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -611,6 +611,7 @@ public class ProfileActivity extends BaseFragment implements NotificationCenter.
|
||||||
private float customAvatarProgress;
|
private float customAvatarProgress;
|
||||||
private float customPhotoOffset;
|
private float customPhotoOffset;
|
||||||
private boolean hasFallbackPhoto;
|
private boolean hasFallbackPhoto;
|
||||||
|
private boolean hasCustomPhoto;
|
||||||
private ImageReceiver fallbackImage;
|
private ImageReceiver fallbackImage;
|
||||||
|
|
||||||
public int getTopicId() {
|
public int getTopicId() {
|
||||||
|
@ -6519,8 +6520,9 @@ public class ProfileActivity extends BaseFragment implements NotificationCenter.
|
||||||
|
|
||||||
boolean onlineTextCrosafade = false;
|
boolean onlineTextCrosafade = false;
|
||||||
|
|
||||||
ChatAvatarContainer avatarContainer = ((ChatActivityInterface) previousTransitionFragment).getAvatarContainer();
|
if (previousTransitionFragment != null) {
|
||||||
if (avatarContainer.getSubtitleTextView().getLeftDrawable() != null || avatarContainer.statusMadeShorter[0]) {
|
ChatAvatarContainer avatarContainer = previousTransitionFragment.getAvatarContainer();
|
||||||
|
if (avatarContainer != null && avatarContainer.getSubtitleTextView().getLeftDrawable() != null || avatarContainer.statusMadeShorter[0]) {
|
||||||
transitionOnlineText = avatarContainer.getSubtitleTextView();
|
transitionOnlineText = avatarContainer.getSubtitleTextView();
|
||||||
avatarContainer2.invalidate();
|
avatarContainer2.invalidate();
|
||||||
onlineTextCrosafade = true;
|
onlineTextCrosafade = true;
|
||||||
|
@ -6528,6 +6530,7 @@ public class ProfileActivity extends BaseFragment implements NotificationCenter.
|
||||||
onlineTextView[1].setAlpha(0f);
|
onlineTextView[1].setAlpha(0f);
|
||||||
animators.add(ObjectAnimator.ofFloat(onlineTextView[1], View.ALPHA, 1.0f));
|
animators.add(ObjectAnimator.ofFloat(onlineTextView[1], View.ALPHA, 1.0f));
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!onlineTextCrosafade) {
|
if (!onlineTextCrosafade) {
|
||||||
for (int a = 0; a < 2; a++) {
|
for (int a = 0; a < 2; a++) {
|
||||||
|
@ -7223,6 +7226,7 @@ public class ProfileActivity extends BaseFragment implements NotificationCenter.
|
||||||
boolean shortStatus;
|
boolean shortStatus;
|
||||||
|
|
||||||
hasFallbackPhoto = false;
|
hasFallbackPhoto = false;
|
||||||
|
hasCustomPhoto = false;
|
||||||
if (userId != 0) {
|
if (userId != 0) {
|
||||||
TLRPC.User user = getMessagesController().getUser(userId);
|
TLRPC.User user = getMessagesController().getUser(userId);
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
|
@ -7288,6 +7292,7 @@ public class ProfileActivity extends BaseFragment implements NotificationCenter.
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
hasCustomPhoto = user.photo != null && user.photo.personal;
|
||||||
try {
|
try {
|
||||||
newString = Emoji.replaceEmoji(newString, nameTextView[1].getPaint().getFontMetricsInt(), AndroidUtilities.dp(24), false);
|
newString = Emoji.replaceEmoji(newString, nameTextView[1].getPaint().getFontMetricsInt(), AndroidUtilities.dp(24), false);
|
||||||
} catch (Exception ignore) {
|
} catch (Exception ignore) {
|
||||||
|
@ -10461,9 +10466,16 @@ public class ProfileActivity extends BaseFragment implements NotificationCenter.
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
if (hasCustomPhoto) {
|
||||||
if (onlineTextView[2] != null) {
|
if (onlineTextView[2] != null) {
|
||||||
onlineTextView[2].setAlpha(photoDescriptionProgress);
|
onlineTextView[2].setAlpha(photoDescriptionProgress);
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
if (onlineTextView[2] != null) {
|
||||||
|
onlineTextView[2].setAlpha(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -2754,31 +2754,43 @@ public class SelectAnimatedEmojiDialog extends FrameLayout implements Notificati
|
||||||
final int maxlen = layoutManager.getSpanCount() * EXPAND_MAX_LINES;
|
final int maxlen = layoutManager.getSpanCount() * EXPAND_MAX_LINES;
|
||||||
for (int i = 0; i < featuredEmojiPacks.size(); ++i) {
|
for (int i = 0; i < featuredEmojiPacks.size(); ++i) {
|
||||||
TLRPC.StickerSetCovered set1 = featuredEmojiPacks.get(i);
|
TLRPC.StickerSetCovered set1 = featuredEmojiPacks.get(i);
|
||||||
if (set1 instanceof TLRPC.TL_stickerSetFullCovered) {
|
TLRPC.StickerSet set = set1.set;
|
||||||
TLRPC.TL_stickerSetFullCovered set = (TLRPC.TL_stickerSetFullCovered) set1;
|
boolean isPremiumPack = false;
|
||||||
boolean foundDuplicate = false;
|
boolean foundDuplicate = false;
|
||||||
for (int j = 0; j < packs.size(); ++j) {
|
for (int j = 0; j < packs.size(); ++j) {
|
||||||
if (packs.get(j).set.id == set.set.id) {
|
if (packs.get(j).set.id == set.id) {
|
||||||
foundDuplicate = true;
|
foundDuplicate = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (foundDuplicate) {
|
if (foundDuplicate) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ArrayList<TLRPC.Document> documents = null;
|
||||||
|
if (set1 instanceof TLRPC.TL_stickerSetNoCovered) {
|
||||||
|
TLRPC.TL_messages_stickerSet fullSet = mediaDataController.getStickerSet(MediaDataController.getInputStickerSet(set1.set), set1.set.hash, true);
|
||||||
|
if (fullSet != null) {
|
||||||
|
documents = fullSet.documents;
|
||||||
|
isPremiumPack = MessageObject.isPremiumEmojiPack(fullSet);
|
||||||
|
}
|
||||||
|
} else if (set1 instanceof TLRPC.TL_stickerSetFullCovered) {
|
||||||
|
documents = ((TLRPC.TL_stickerSetFullCovered) set1).documents;
|
||||||
|
isPremiumPack = MessageObject.isPremiumEmojiPack(set1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (documents != null) {
|
||||||
positionToSection.put(totalCount, packs.size());
|
positionToSection.put(totalCount, packs.size());
|
||||||
sectionToPosition.put(packs.size(), totalCount);
|
sectionToPosition.put(packs.size(), totalCount);
|
||||||
totalCount++;
|
totalCount++;
|
||||||
rowHashCodes.add(Objects.hash(9211, set.set.id));
|
rowHashCodes.add(Objects.hash(9211, set.id));
|
||||||
|
|
||||||
EmojiView.EmojiPack pack = new EmojiView.EmojiPack();
|
EmojiView.EmojiPack pack = new EmojiView.EmojiPack();
|
||||||
pack.installed = installedEmojiSets.contains(set.set.id);
|
pack.installed = installedEmojiSets.contains(set.id);
|
||||||
pack.featured = true;
|
pack.featured = true;
|
||||||
pack.free = !MessageObject.isPremiumEmojiPack(set);
|
pack.free = !isPremiumPack;
|
||||||
pack.set = set.set;
|
pack.set = set;
|
||||||
pack.documents = set.documents;
|
pack.documents = documents;
|
||||||
pack.index = packs.size();
|
pack.index = packs.size();
|
||||||
pack.expanded = expandedEmojiSets.contains(pack.set.id);
|
pack.expanded = expandedEmojiSets.contains(pack.set.id);
|
||||||
|
|
||||||
|
@ -2787,7 +2799,7 @@ public class SelectAnimatedEmojiDialog extends FrameLayout implements Notificati
|
||||||
for (int k = 0; k < maxlen - 1; ++k) {
|
for (int k = 0; k < maxlen - 1; ++k) {
|
||||||
rowHashCodes.add(Objects.hash(3212, pack.documents.get(k).id));
|
rowHashCodes.add(Objects.hash(3212, pack.documents.get(k).id));
|
||||||
}
|
}
|
||||||
rowHashCodes.add(Objects.hash(-5531, set.set.id, (pack.documents.size() - maxlen + 1)));
|
rowHashCodes.add(Objects.hash(-5531, set.id, (pack.documents.size() - maxlen + 1)));
|
||||||
positionToExpand.put(totalCount - 1, packs.size());
|
positionToExpand.put(totalCount - 1, packs.size());
|
||||||
} else {
|
} else {
|
||||||
totalCount += pack.documents.size();
|
totalCount += pack.documents.size();
|
||||||
|
@ -2799,7 +2811,7 @@ public class SelectAnimatedEmojiDialog extends FrameLayout implements Notificati
|
||||||
if (!pack.installed) {
|
if (!pack.installed) {
|
||||||
positionToButton.put(totalCount, packs.size());
|
positionToButton.put(totalCount, packs.size());
|
||||||
totalCount++;
|
totalCount++;
|
||||||
rowHashCodes.add(Objects.hash(3321, set.set.id));
|
rowHashCodes.add(Objects.hash(3321, set.id));
|
||||||
}
|
}
|
||||||
|
|
||||||
packs.add(pack);
|
packs.add(pack);
|
||||||
|
@ -3522,6 +3534,8 @@ public class SelectAnimatedEmojiDialog extends FrameLayout implements Notificati
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Runnable updateRowsDelayed = () -> updateRows(true, true);
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void didReceivedNotification(int id, int account, Object... args) {
|
public void didReceivedNotification(int id, int account, Object... args) {
|
||||||
if (id == NotificationCenter.stickersDidLoad) {
|
if (id == NotificationCenter.stickersDidLoad) {
|
||||||
|
@ -3533,10 +3547,8 @@ public class SelectAnimatedEmojiDialog extends FrameLayout implements Notificati
|
||||||
} else if (id == NotificationCenter.recentEmojiStatusesUpdate) {
|
} else if (id == NotificationCenter.recentEmojiStatusesUpdate) {
|
||||||
updateRows(false, true);
|
updateRows(false, true);
|
||||||
} else if (id == NotificationCenter.groupStickersDidLoad) {
|
} else if (id == NotificationCenter.groupStickersDidLoad) {
|
||||||
if (defaultSetLoading) {
|
AndroidUtilities.cancelRunOnUIThread(updateRowsDelayed);
|
||||||
updateRows(true, true);
|
AndroidUtilities.runOnUIThread(updateRowsDelayed, 100);
|
||||||
defaultSetLoading = false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1889,7 +1889,7 @@ public class TopicsFragment extends BaseFragment implements NotificationCenter.N
|
||||||
|
|
||||||
private void checkLoading() {
|
private void checkLoading() {
|
||||||
loadingTopics = topicsController.isLoading(chatId);
|
loadingTopics = topicsController.isLoading(chatId);
|
||||||
if (topicsEmptyView != null/* && forumTopics.size() == 0*/) {
|
if (topicsEmptyView != null && (forumTopics.size() == 0 || (forumTopics.size() == 1 && forumTopics.get(0).topic.id == 1))) {
|
||||||
topicsEmptyView.showProgress(loadingTopics, fragmentBeginToShow);
|
topicsEmptyView.showProgress(loadingTopics, fragmentBeginToShow);
|
||||||
}
|
}
|
||||||
if (recyclerListView != null) {
|
if (recyclerListView != null) {
|
||||||
|
@ -2547,8 +2547,8 @@ public class TopicsFragment extends BaseFragment implements NotificationCenter.N
|
||||||
adapter.setItems(oldItems, forumTopics);
|
adapter.setItems(oldItems, forumTopics);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (scrollToTop && layoutManager != null) {
|
if ((scrollToTop || oldCount == 0) && layoutManager != null) {
|
||||||
layoutManager.scrollToPosition(0);
|
layoutManager.scrollToPositionWithOffset(0, 0);
|
||||||
scrollToTop = false;
|
scrollToTop = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,8 +13,8 @@
|
||||||
# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
|
# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
|
||||||
# org.gradle.parallel=true
|
# org.gradle.parallel=true
|
||||||
#Sat Mar 12 05:53:50 MSK 2016
|
#Sat Mar 12 05:53:50 MSK 2016
|
||||||
APP_VERSION_NAME=9.3.2
|
APP_VERSION_NAME=9.3.3
|
||||||
APP_VERSION_CODE=3023
|
APP_VERSION_CODE=3026
|
||||||
APP_PACKAGE=org.telegram.messenger
|
APP_PACKAGE=org.telegram.messenger
|
||||||
RELEASE_KEY_PASSWORD=TelegramAndroidPswd
|
RELEASE_KEY_PASSWORD=TelegramAndroidPswd
|
||||||
RELEASE_KEY_ALIAS=tmessages
|
RELEASE_KEY_ALIAS=tmessages
|
||||||
|
|
Loading…
Reference in a new issue