Fixed its hole bug bug

This commit is contained in:
Igor Zhukov 2015-11-27 15:47:03 +03:00
parent 199a6eb3f0
commit 6a09ee41ef
7 changed files with 78 additions and 22 deletions

View File

@ -4660,7 +4660,7 @@ angular.module('myApp.controllers', ['myApp.i18n'])
}) })
.controller('StickersetModalController', function ($scope, MtpApiManager, AppStickersManager) { .controller('StickersetModalController', function ($scope, MtpApiManager, RichTextProcessor, AppStickersManager) {
$scope.slice = {limit: 20, limitDelta: 20}; $scope.slice = {limit: 20, limitDelta: 20};
AppStickersManager.getStickerset($scope.inputStickerset).then(function (result) { AppStickersManager.getStickerset($scope.inputStickerset).then(function (result) {
@ -4669,6 +4669,31 @@ angular.module('myApp.controllers', ['myApp.i18n'])
$scope.stickerset = result.set; $scope.stickerset = result.set;
$scope.stickersetInstalled = result.installed; $scope.stickersetInstalled = result.installed;
$scope.documents = result.documents; $scope.documents = result.documents;
$scope.stickerEmojis = {};
angular.forEach($scope.documents, function (doc) {
$scope.stickerEmojis[doc.id] = RichTextProcessor.wrapRichText(doc.stickerEmojiRaw, {
noLinks: true,
noLinebreaks: true,
emojiIconSize: 26
});
});
// if (doc.id && doc.access_hash) {
// var inputMedia = {
// _: 'inputMediaDocument',
// id: {
// _: 'inputDocument',
// id: doc.id,
// access_hash: doc.access_hash
// }
// }
// var options = {
// replyToMsgID: $scope.draftMessage.replyToMessage && $scope.draftMessage.replyToMessage.mid
// };
// AppMessagesManager.sendOther($scope.curDialog.peerID, inputMedia, options);
// $scope.$broadcast('ui_message_send');
// }
}); });
$scope.toggleInstalled = function (installed) { $scope.toggleInstalled = function (installed) {

View File

@ -1074,7 +1074,7 @@ angular.module('myApp.directives', ['myApp.filters'])
function updateSizes () { function updateSizes () {
$(element).css({ $(element).css({
height: Math.min(500, $($window).height() height: Math.min(600, $($window).height()
- (Config.Mobile ? 46 + 18 : 200)) - (Config.Mobile ? 46 + 18 : 200))
}); });
$(stickersWrap).nanoScroller(); $(stickersWrap).nanoScroller();

View File

@ -1484,6 +1484,7 @@ angular.module('izhukov.utils', [])
var url; var url;
var html = []; var html = [];
var lastOffset = 0; var lastOffset = 0;
var curEmojiSize = options.emojiIconSize || emojiIconSize;
for (i = 0; i < len; i++) { for (i = 0; i < len; i++) {
entity = entities[i]; entity = entities[i];
if (entity.offset > lastOffset) { if (entity.offset > lastOffset) {
@ -1600,9 +1601,9 @@ angular.module('izhukov.utils', [])
'<span class="emoji emoji-', '<span class="emoji emoji-',
entity.coords.category, entity.coords.category,
'-', '-',
(emojiIconSize * entity.coords.column), (curEmojiSize * entity.coords.column),
'-', '-',
(emojiIconSize * entity.coords.row), (curEmojiSize * entity.coords.row),
'" ', '" ',
'title="', entity.title, '">', 'title="', entity.title, '">',
':', entity.title, ':</span>' ':', entity.title, ':</span>'
@ -1675,8 +1676,9 @@ angular.module('izhukov.utils', [])
if (!options.nested && (emojiFound || options.hasNested)) { if (!options.nested && (emojiFound || options.hasNested)) {
text = text.replace(/\ufe0f|&#65039;|&#65533;|&#8205;/g, '', text); text = text.replace(/\ufe0f|&#65039;|&#65533;|&#8205;/g, '', text);
var emojiSizeClass = curEmojiSize == 18 ? '' : (' emoji-w' + curEmojiSize);
text = text.replace(/<span class="emoji emoji-(\d)-(\d+)-(\d+)"(.+?)<\/span>/g, text = text.replace(/<span class="emoji emoji-(\d)-(\d+)-(\d+)"(.+?)<\/span>/g,
'<span class="emoji emoji-spritesheet-$1" style="background-position: -$2px -$3px;" $4</span>'); '<span class="emoji ' + emojiSizeClass + ' emoji-spritesheet-$1" style="background-position: -$2px -$3px;" $4</span>');
} }
return $sce.trustAs('html', text); return $sce.trustAs('html', text);

View File

@ -1051,7 +1051,16 @@ angular.module('myApp.services')
apiPromise = MtpApiManager.invokeApi('messages.readHistory', { apiPromise = MtpApiManager.invokeApi('messages.readHistory', {
peer: AppPeersManager.getInputPeerByID(peerID), peer: AppPeersManager.getInputPeerByID(peerID),
max_id: 0 max_id: 0
}).then(function (affectedMessages) {
ApiUpdatesManager.processUpdateMessage({
_: 'updateShort',
update: {
_: 'updatePts',
pts: affectedMessages.pts,
pts_count: affectedMessages.pts_count
}
}); });
})
} }
historyStorage.readPromise = apiPromise.then(function () { historyStorage.readPromise = apiPromise.then(function () {

View File

@ -2650,6 +2650,7 @@ angular.module('myApp.services', ['myApp.i18n', 'izhukov.utils'])
} }
function getDifference () { function getDifference () {
console.trace(dT(), 'Get full diff');
if (!updatesState.syncLoading) { if (!updatesState.syncLoading) {
updatesState.syncLoading = true; updatesState.syncLoading = true;
updatesState.pendingSeqUpdates = {}; updatesState.pendingSeqUpdates = {};
@ -2721,12 +2722,18 @@ angular.module('myApp.services', ['myApp.i18n', 'izhukov.utils'])
channelState.syncLoading = true; channelState.syncLoading = true;
channelState.pendingPtsUpdates = []; channelState.pendingPtsUpdates = [];
} }
if (channelState.syncPending) {
clearTimeout(channelState.syncPending.timeout);
channelState.syncPending = false;
}
console.log(dT(), 'Get channel diff', AppChatsManager.getChat(channelID), channelState.pts);
MtpApiManager.invokeApi('updates.getChannelDifference', { MtpApiManager.invokeApi('updates.getChannelDifference', {
channel: AppChatsManager.getChannelInput(channelID), channel: AppChatsManager.getChannelInput(channelID),
filter: {_: 'channelMessagesFilterEmpty'}, filter: {_: 'channelMessagesFilterEmpty'},
pts: channelState.pts, pts: channelState.pts,
limit: 10 limit: 30
}).then(function (differenceResult) { }).then(function (differenceResult) {
console.log(dT(), 'channel diff result', differenceResult);
channelState.pts = differenceResult.pts; channelState.pts = differenceResult.pts;
if (differenceResult._ == 'updates.channelDifferenceEmpty') { if (differenceResult._ == 'updates.channelDifferenceEmpty') {
@ -2809,12 +2816,16 @@ angular.module('myApp.services', ['myApp.i18n', 'izhukov.utils'])
channelID = update.channel_id; channelID = update.channel_id;
break; break;
} }
// if (channelID) {
// console.log(dT(), channelID, update.pts, update);
// }
if (channelID && !AppChatsManager.hasChat(channelID)) { if (channelID && !AppChatsManager.hasChat(channelID)) {
console.log(dT(), 'skip update, missing channel', channelID, update);
return false; return false;
} }
var curState = channelID ? getChannelState(channelID, update.pts) : updatesState; var curState = channelID ? getChannelState(channelID, update.pts) : updatesState;
// console.log('process', channelID, curState, update); console.log(dT(), 'process', channelID, curState, update);
if (curState.syncLoading) { if (curState.syncLoading) {
return false; return false;
@ -2840,7 +2851,7 @@ angular.module('myApp.services', ['myApp.i18n', 'izhukov.utils'])
if (update.pts) { if (update.pts) {
var newPts = curState.pts + (update.pts_count || 0); var newPts = curState.pts + (update.pts_count || 0);
if (newPts < update.pts) { if (newPts < update.pts) {
console.log(dT(), 'Pts hole', curState, update); console.warn(dT(), 'Pts hole', curState, update, channelID && AppChatsManager.getChat(channelID));
curState.pendingPtsUpdates.push(update); curState.pendingPtsUpdates.push(update);
if (!curState.syncPending) { if (!curState.syncPending) {
curState.syncPending = { curState.syncPending = {
@ -2860,6 +2871,9 @@ angular.module('myApp.services', ['myApp.i18n', 'izhukov.utils'])
curState.pts = update.pts; curState.pts = update.pts;
popPts = true; popPts = true;
} }
if (channelID && options.date && updatesState.date < options.date) {
updatesState.date = options.date;
}
} }
else if (!channelID && options.seq > 0) { else if (!channelID && options.seq > 0) {
var seq = options.seq; var seq = options.seq;

View File

@ -3366,28 +3366,34 @@ ul.chat_modal_migrate_list {
.stickerset_modal_window .modal-dialog { .stickerset_modal_window .modal-dialog {
max-width: 474px; max-width: 642px;
width: auto;
} }
.stickerset_modal_stickers_list { .stickerset_modal_stickers_list {
padding: 25px; padding: 25px;
} }
.stickerset_modal_sticker_wrap { .stickerset_modal_sticker_wrap {
list-style: none; margin: 0 5px 5px 0;
margin: 0 10px 10px 0;
padding: 0; padding: 0;
position: relative; position: relative;
display: block; display: block;
width: 96px; width: 192px;
height: 96px; height: 192px;
float: left; float: left;
border-radius: 3px;
overflow: hidden;
&:hover {
background: #f2f6fa;
}
} }
.stickerset_modal_sticker { .stickerset_modal_sticker {
width: 96px; width: 192px;
height: 96px; height: 192px;
} }
.stickerset_modal_sticker img { .stickerset_modal_sticker img {
max-width: 96px; max-width: 192px;
max-height: 96px; max-height: 192px;
} }
.stickerset_modal_sticker_alt { .stickerset_modal_sticker_alt {
position: absolute; position: absolute;

View File

@ -26,10 +26,10 @@
</div> </div>
<div ng-switch-default class="stickerset_modal_stickers_list clearfix"> <div ng-switch-default class="stickerset_modal_stickers_list clearfix">
<div class="stickerset_modal_sticker_wrap" ng-repeat="sticker in documents | limitTo: slice.limit"> <a class="stickerset_modal_sticker_wrap" ng-repeat="sticker in documents | limitTo: slice.limit" ng-click="chooseSticker(sticker.id)">
<div class="stickerset_modal_sticker" my-load-sticker document="sticker" thumb="true"></div> <div class="stickerset_modal_sticker" my-load-sticker document="sticker"></div>
<div class="stickerset_modal_sticker_alt" ng-bind-html="sticker.stickerEmoji"></div> <div class="stickerset_modal_sticker_alt" ng-bind-html="stickerEmojis[sticker.id]"></div>
</div> </a>
</div> </div>
</div> </div>