Browse Source

Fixed contacts search

master
Igor Zhukov 7 years ago
parent
commit
d817e955ab
  1. 27
      app/js/controllers.js

27
app/js/controllers.js

@ -1308,8 +1308,8 @@ angular.module('myApp.controllers', ['myApp.i18n'])
selectedCancel(true) selectedCancel(true)
if (oldDialog.peer && if (oldDialog.peer &&
oldDialog.peer == newDialog.peer && oldDialog.peer == newDialog.peer &&
newDialog.messageID) { newDialog.messageID) {
messageFocusHistory() messageFocusHistory()
} else if (peerID) { } else if (peerID) {
updateHistoryPeer(true) updateHistoryPeer(true)
@ -4800,7 +4800,7 @@ angular.module('myApp.controllers', ['myApp.i18n'])
} }
}) })
.controller('ContactsModalController', function ($scope, $rootScope, $timeout, $modal, $modalInstance, MtpApiManager, AppUsersManager, ErrorService) { .controller('ContactsModalController', function ($scope, $rootScope, $timeout, $modal, $modalInstance, MtpApiManager, AppPeersManager, AppUsersManager, ErrorService) {
$scope.contacts = [] $scope.contacts = []
$scope.foundPeers = [] $scope.foundPeers = []
$scope.search = {} $scope.search = {}
@ -4852,20 +4852,25 @@ angular.module('myApp.controllers', ['myApp.i18n'])
$scope.$broadcast('contacts_change') $scope.$broadcast('contacts_change')
}) })
if (query && query.length >= 5) { if (query && query.length >= 2) {
$timeout(function () { $timeout(function () {
if (curJump != jump) return if (curJump != jump) return
MtpApiManager.invokeApi('contacts.search', {q: query, limit: 10}).then(function (result) { MtpApiManager.invokeApi('contacts.search', {q: query, limit: 10}).then(function (result) {
AppUsersManager.saveApiUsers(result.users) AppUsersManager.saveApiUsers(result.users)
if (curJump != jump) return if (curJump != jump) return
angular.forEach(result.results, function (contactFound) { var myPeersLen = result.my_results.length
var userID = contactFound.user_id var foundPeers = result.my_results.concat(result.results)
if (doneIDs.indexOf(userID) != -1) return angular.forEach(foundPeers, function (peerFound, i) {
var peerID = AppPeersManager.getPeerID(peerFound)
if (peerID <= 0 ||
doneIDs.indexOf(peerID) != -1) {
return
}
$scope.contacts.push({ $scope.contacts.push({
userID: userID, userID: peerID,
user: AppUsersManager.getUser(userID), user: AppUsersManager.getUser(peerID),
peerString: AppUsersManager.getUserString(userID), peerString: AppUsersManager.getUserString(peerID),
found: true found: i >= myPeersLen
}) })
}) })
}, function (error) { }, function (error) {

Loading…
Cancel
Save