Ionic: Как заставить Angular Translate js работать с поисковым фильтром при смене языка?

Проблема решена. Решение отредактировано в этом вопросе. Спасибо "прашик".

Я не могу заставить Angular Translate работать с Search Filter . Когда язык английский, элементы списка доступны для поиска на английском языке, как обычно. Но когда используется язык Bangla, элементы по-прежнему доступны для поиска на английском языке, но не на Bangla. Есть ли решение?

Вид

<ion-list>
            <ion-item>
              <label class="item item-input">
                <i class="icon ion-search placeholder-icon"></i>
                <input type="text" ng-model="input.filterUser" placeholder="Search">
              </label>
            </ion-item>
              <ion-item class="item-avatar" ng-repeat="user in groups | filter:input.filterUser">
                <img src="{{user.avatar}}">           
                <h2>{{user.name | translate}}</h2>
                <p>{{user.fullname}}
                  {{user.email}}</p>       
              </ion-item>        
          </ion-list>

Контроллер

.controller('CreditCtrl', function($scope, $ionicConfig, $translate) {

  $scope.input = {};  
  $scope.groups = [
  {
  index: 1,
  index_start_at: 56,
  name:  "Bnd_Nilgiri",
  surname: "Hayes",
  fullname: "Grace Beatty",
  email: "[email protected]",
  bool: false,
  avatar: "img/ionic.png"
  },
  {
  index: 2,
  index_start_at: 57,
  name: "Bnd_Nilachal",
  surname: "Shayes",
  fullname: "Srace Beatty",
  email: "[email protected]",
  bool: false,
  avatar: "img/ionic.png"
  }
];



 angular.forEach($scope.groups, function(user, index){
      $translate(user.name, {user: user}).then(function(translated){
        $scope.groups[index].name = translated;
      });
    });

})

Поставщик перевода

.config(function($stateProvider, $urlRouterProvider, $ionicConfigProvider, $translateProvider) {

 $translateProvider.translations('en', {
    Bnd_Nilgiri : 'Nilgiri Tourspot',
    Bnd_Nilachal : 'Nilachal Tourspot',
    Bnd_Bogalake : 'Bogalake Tourspot',    
  });
  $translateProvider.translations('de', {
    // Bandarban Tour Spots

    Bnd_Nilgiri : 'নিলগিরি ট্যুর স্পট',
    Bnd_Nilachal : 'নিলাচল ট্যুর স্পট',
    Bnd_Bogalake : 'বগালেক ট্যুর স্পট',
  });
  $translateProvider.preferredLanguage('en');

person Shuvo Habib    schedule 28.09.2015    source источник


Ответы (1)


Это потому, что ваш фильтр | translate применяется после углового фильтра.

Единственным возможным решением было бы предварительное преобразование массива groups. Вам нужно будет использовать службу $translate в вашем контроллере, прежде чем применять ее к переменной groups:

var en_translations =  {
    Bnd_Nilgiri : 'Nilgiri Tourspot',
    Bnd_Nilachal : 'Nilachal Tourspot',
    Bnd_Bogalake : 'Bogalake Tourspot',    
}

var de_translations = {
    Bnd_Nilgiri : 'নিলগিরি ট্যুর স্পট',
    Bnd_Nilachal : 'নিলাচল ট্যুর স্পট',
    Bnd_Bogalake : 'বগালেক ট্যুর স্পট',
};


var app = angular.module('myApp', ['pascalprecht.translate']);

app.config(['$translateProvider', function ($translateProvider) {
  // add translation table
  $translateProvider
    .translations('en', en_translations)
    .translations('de', de_translations)
    .preferredLanguage('de');
}]);

app.controller('Ctrl', ['$scope', '$translate', function ($scope, $translate) {
  // expose translation via `$translate` service
  $scope.groups =  [
    {
      index: 1,
      index_start_at: 56,
      name:  "Bnd_Nilgiri",
      surname: "Hayes",
      fullname: "Grace Beatty",
      email: "[email protected]",
      bool: false,
      avatar: "img/ionic.png"
    },
    {
      index: 2,
      index_start_at: 57,
      name: "Bnd_Nilachal",
      surname: "Shayes",
      fullname: "Srace Beatty",
      email: "[email protected]",
      bool: false,
      avatar: "img/ionic.png"
    }
  ];
  angular.forEach($scope.groups, function(user, index){
    $translate(user.name, {user: user}).then(function(translated){
      $scope.groups[index].name = translated;
    });
  });

}]);

Я не тестировал код, но я думаю, что именно так это и происходит. В основном filter:input.filterUser работает с массивом $scope.groups, который еще не переведен, поэтому вам нужно перевести его до того, как произойдет ng-repeat.

EDIT: я сделал plunkr здесь, чтобы продемонстрировать приведенный выше код: http://plnkr.co/edit/sVgUIlFxfs6pDsdR2ydQ

person Pascal Raszyk    schedule 28.09.2015
comment
Спасибо, praszyk, что нашли время и ответили на мой вопрос. Мой контроллер похож на код вопроса, который я только что отредактировал. Пожалуйста, посмотрите. - person Shuvo Habib; 28.09.2015
comment
Можете ли вы опубликовать части вашего объекта перевода? - person Pascal Raszyk; 28.09.2015
comment
1 мин . Я снова редактирую вопрос. Заранее спасибо. - person Shuvo Habib; 28.09.2015
comment
Извините за поздний ответ. Большое спасибо. Оно работает. - person Shuvo Habib; 09.10.2015