Fixed CHAT_ID_INVALID

Closes #998
This commit is contained in:
Igor Zhukov 2015-12-07 20:28:20 +03:00
parent 5268f5b14d
commit df163320b6

View File

@ -593,18 +593,7 @@ angular.module('myApp.controllers', ['myApp.i18n'])
updateCurDialog(); updateCurDialog();
var lastSearch = false;
function updateCurDialog() { function updateCurDialog() {
if ($routeParams.q) {
if ($routeParams.q !== lastSearch) {
$scope.search.query = lastSearch = $routeParams.q;
if ($scope.curDialog !== undefined) {
return false;
}
}
} else {
lastSearch = false;
}
var addParams = pendingParams || {}; var addParams = pendingParams || {};
pendingParams = false; pendingParams = false;
addParams.messageID = parseInt(addParams.messageID) || false; addParams.messageID = parseInt(addParams.messageID) || false;
@ -613,7 +602,10 @@ angular.module('myApp.controllers', ['myApp.i18n'])
var peerStringPromise; var peerStringPromise;
if ($routeParams.p && $routeParams.p.charAt(0) == '@') { if ($routeParams.p && $routeParams.p.charAt(0) == '@') {
if ($scope.curDialog === undefined) { if ($scope.curDialog === undefined) {
$scope.curDialog = {}; $scope.curDialog = {
peer: '',
peerID: 0
};
} }
peerStringPromise = AppPeersManager.resolveUsername($routeParams.p.substr(1)).then(function (peerID) { peerStringPromise = AppPeersManager.resolveUsername($routeParams.p.substr(1)).then(function (peerID) {
return qSync.when(AppPeersManager.getPeerString(peerID)); return qSync.when(AppPeersManager.getPeerString(peerID));
@ -623,7 +615,8 @@ angular.module('myApp.controllers', ['myApp.i18n'])
} }
peerStringPromise.then(function (peerString) { peerStringPromise.then(function (peerString) {
$scope.curDialog = angular.extend({ $scope.curDialog = angular.extend({
peer: peerString peer: peerString,
peerID: AppPeersManager.getPeerID(peerString || '')
}, addParams); }, addParams);
if (pendingAttachment) { if (pendingAttachment) {
$scope.$broadcast('peer_draft_attachment', pendingAttachment); $scope.$broadcast('peer_draft_attachment', pendingAttachment);
@ -1112,20 +1105,16 @@ angular.module('myApp.controllers', ['myApp.i18n'])
lessPending = false; lessPending = false;
function applyDialogSelect (newDialog, oldDialog) { function applyDialogSelect (newDialog, oldDialog) {
var newPeer = newDialog.peer || $scope.curDialog.peer || ''; if (oldDialog.peer == newDialog.peer &&
peerID = AppPeersManager.getPeerID(newPeer);
if (peerID == $scope.curDialog.peerID &&
oldDialog.messageID == newDialog.messageID && oldDialog.messageID == newDialog.messageID &&
oldDialog.startParam == newDialog.startParam) { oldDialog.startParam == newDialog.startParam) {
return false; return false;
} }
$rootScope.selectedPeerID = peerID; peerID = $rootScope.selectedPeerID = newDialog.peerID;
$scope.curDialog.peerID = peerID;
$scope.historyFilter.mediaType = false; $scope.historyFilter.mediaType = false;
AppPeersManager.getInputPeer(newPeer); AppPeersManager.getInputPeer(newDialog.peer || $scope.curDialog.peer || '');
updateBotActions(); updateBotActions();
selectedCancel(true); selectedCancel(true);
@ -1135,7 +1124,7 @@ angular.module('myApp.controllers', ['myApp.i18n'])
newDialog.messageID) { newDialog.messageID) {
messageFocusHistory(); messageFocusHistory();
} }
else if (peerID) { else if (newDialog.peerID) {
updateHistoryPeer(true); updateHistoryPeer(true);
loadHistory(); loadHistory();
} }
@ -1834,7 +1823,6 @@ angular.module('myApp.controllers', ['myApp.i18n'])
var typingTimeouts = {}; var typingTimeouts = {};
$scope.$on('history_append', function (e, addedMessage) { $scope.$on('history_append', function (e, addedMessage) {
var history = historiesQueueFind(addedMessage.peerID); var history = historiesQueueFind(addedMessage.peerID);
// var history = historiesQueuePush(addedMessage.peerID);
if (!history) { if (!history) {
return; return;
} }
@ -2194,9 +2182,7 @@ angular.module('myApp.controllers', ['myApp.i18n'])
function updateCommands () { function updateCommands () {
var peerID = $scope.curDialog.peerID; var peerID = $scope.curDialog.peerID;
if (peerID === undefined) { if (!peerID) {
console.warn('undefined peerID', $scope.curDialog);
console.trace();
safeReplaceObject($scope.commands, {}); safeReplaceObject($scope.commands, {});
$scope.$broadcast('mentions_update'); $scope.$broadcast('mentions_update');
return; return;