Improved stickers updates logic

This commit is contained in:
Igor Zhukov 2016-01-21 22:47:00 +00:00
parent d0a2f7b587
commit 3962309545
2 changed files with 78 additions and 27 deletions

View File

@ -4657,11 +4657,14 @@ angular.module('myApp.controllers', ['myApp.i18n'])
.controller('StickersetModalController', function ($scope, $rootScope, $modalInstance, MtpApiManager, RichTextProcessor, AppStickersManager, AppDocsManager, AppMessagesManager, LocationParamsService) { .controller('StickersetModalController', function ($scope, $rootScope, $modalInstance, MtpApiManager, RichTextProcessor, AppStickersManager, AppDocsManager, AppMessagesManager, LocationParamsService) {
$scope.slice = {limit: 20, limitDelta: 20}; $scope.slice = {limit: 20, limitDelta: 20};
var fullSet;
AppStickersManager.getStickerset($scope.inputStickerset).then(function (result) { AppStickersManager.getStickerset($scope.inputStickerset).then(function (result) {
$scope.$broadcast('ui_height'); $scope.$broadcast('ui_height');
$scope.stickersetLoaded = true; $scope.stickersetLoaded = true;
fullSet = result;
$scope.stickerset = result.set; $scope.stickerset = result.set;
$scope.stickersetInstalled = result.set.pFlags.installed; $scope.stickersetInstalled = result.set.pFlags.installed == true;
$scope.documents = result.documents; $scope.documents = result.documents;
$scope.stickerEmojis = {}; $scope.stickerEmojis = {};
@ -4676,7 +4679,7 @@ angular.module('myApp.controllers', ['myApp.i18n'])
}); });
$scope.toggleInstalled = function (installed) { $scope.toggleInstalled = function (installed) {
AppStickersManager.installStickerset($scope.stickerset, !installed).then(function () { AppStickersManager.installStickerset(fullSet, !installed).then(function () {
$scope.stickersetInstalled = installed; $scope.stickersetInstalled = installed;
}) })
}; };

View File

@ -1222,6 +1222,7 @@ angular.module('myApp.services', ['myApp.i18n', 'izhukov.utils'])
}); });
break; break;
} }
return $q.reject(error);
}); });
} }
@ -2277,20 +2278,69 @@ angular.module('myApp.services', ['myApp.i18n', 'izhukov.utils'])
} }
}) })
.service('AppStickersManager', function ($q, $rootScope, $modal, _, FileManager, MtpApiManager, MtpApiFileManager, AppDocsManager, Storage) { .service('AppStickersManager', function ($q, $rootScope, $modal, _, FileManager, MtpApiManager, MtpApiFileManager, AppDocsManager, Storage, ApiUpdatesManager) {
var currentStickers = [];
var currentStickersets = [];
var stickersetItems = {};
var applied = false;
var started = false; var started = false;
var applied = false;
var currentStickerSets = [];
$rootScope.$on('apiUpdate', function (e, update) { $rootScope.$on('apiUpdate', function (e, update) {
var rewriteCached = false;
if (update._ == 'updateStickerSets') { if (update._ == 'updateStickerSets') {
// Storage.remove('all_stickers').then(function () { getStickers(true);
// getStickers(true); return true;
// });
} }
if (update._ != 'updateNewStickerSet' &&
update._ != 'updateDelStickerSet' &&
update._ != 'updateStickerSetsOrder') {
return false;
}
return Storage.get('all_stickers').then(function (stickers) {
if (stickers &&
stickers.layer == Config.Schema.API.layer) {
switch (update._) {
case 'updateNewStickerSet':
var fullSet = update.stickerset;
var set = fullSet.set;
set.pFlags.installed = true;
stickers.fullSets[set.id] = fullSet;
var pos = false;
for (var i = 0, len = stickers.sets.length; i < len; i++) {
if (stickers.sets[i].id == set.id) {
pos = i;
break;
}
}
if (pos !== false) {
stickers.sets.splice(pos, 1);
}
stickers.sets.unshift(set);
break;
case 'updateDelStickerSet':
for (var i = 0, len = stickers.sets.length; i < len; i++) {
if (stickers.sets[i].id == update.id) {
stickers.sets.splice(i, 1);
break;
}
}
delete stickers.fullSets[update.id];
break;
case 'updateStickerSetsOrder':
var order = update.order;
stickers.sets.sort(function (a, b) {
return order.indexOf(a.id) - order.indexOf(b.id);
});
break;
}
Storage.set({all_stickers: stickers}).then(function () {
getStickers(true)
});
}
});
}); });
return { return {
@ -2357,7 +2407,7 @@ angular.module('myApp.services', ['myApp.i18n', 'izhukov.utils'])
applied = stickers.hash; applied = stickers.hash;
var i, j, len1, len2, doc, set, docIDs, documents; var i, j, len1, len2, doc, set, docIDs, documents;
currentStickersets = []; currentStickerSets = [];
len1 = stickers.sets.length; len1 = stickers.sets.length;
for (i = 0; i < len1; i++) { for (i = 0; i < len1; i++) {
set = stickers.sets[i]; set = stickers.sets[i];
@ -2373,13 +2423,14 @@ angular.module('myApp.services', ['myApp.i18n', 'izhukov.utils'])
docIDs.push(doc.id); docIDs.push(doc.id);
} }
set.docIDs = docIDs; set.docIDs = docIDs;
currentStickerSets.push(set);
} }
} }
return getPopularStickers().then(function (popularStickers) { return getPopularStickers().then(function (popularStickers) {
var resultStickersets = currentStickersets; var resultStickersets = currentStickerSets;
if (popularStickers.length) { if (popularStickers.length) {
resultStickersets = currentStickersets.slice(); resultStickersets = currentStickerSets.slice();
var docIDs = []; var docIDs = [];
var i, len; var i, len;
for (i = 0, len = popularStickers.length; i < len; i++) { for (i = 0, len = popularStickers.length; i < len; i++) {
@ -2393,6 +2444,7 @@ angular.module('myApp.services', ['myApp.i18n', 'izhukov.utils'])
}); });
} }
console.log('stickers', resultStickersets);
return resultStickersets; return resultStickersets;
}); });
} }
@ -2466,33 +2518,29 @@ angular.module('myApp.services', ['myApp.i18n', 'izhukov.utils'])
}); });
} }
function installStickerset (set, uninstall) { function installStickerset (fullSet, uninstall) {
var method = uninstall var method = uninstall
? 'messages.uninstallStickerSet' ? 'messages.uninstallStickerSet'
: 'messages.installStickerSet'; : 'messages.installStickerSet';
var inputStickerset = { var inputStickerset = {
_: 'inputStickerSetID', _: 'inputStickerSetID',
id: set.id, id: fullSet.set.id,
access_hash: set.access_hash access_hash: fullSet.set.access_hash
}; };
return MtpApiManager.invokeApi(method, { return MtpApiManager.invokeApi(method, {
stickerset: inputStickerset, stickerset: inputStickerset,
disabled: false disabled: false
}).then(function (result) { }).then(function (result) {
var update;
if (uninstall) { if (uninstall) {
update = {_: 'updateDelStickerSet', id: fullSet.set.id};
} else { } else {
update = {_: 'updateNewStickerSet', stickerset: fullSet};
}
ApiUpdatesManager.processUpdateMessage({ ApiUpdatesManager.processUpdateMessage({
_: 'updateShort', _: 'updateShort',
update: { update: update
_: 'updateNewStickerSet',
channel_id: channelID,
messages: msgIDs,
pts: affectedMessages.pts,
pts_count: affectedMessages.pts_count
}
}); });
}
}); });
} }