(function(){ 'use strict'; app.directive('langSwitcher', langSwitcher); function langSwitcher(){ return { restrict: 'E', templateUrl: './app/directive/lang-swicher/lang-swicher.template.html', scope: {}, controller: ['$scope', '$translate', function($scope, $translate){ $scope.languages = [ {key: 'en', value: 'English'}, {key: 'ru', value: 'Russian'} ]; $scope.showMenu = false; $scope.toggleMenu = function(){ $scope.showMenu = !$scope.showMenu } var key = localStorage.getItem('preferredLanguage') || 'en' $scope.currentLang = $scope.languages.filter(function(item){ return item.key === key; })[0]; $scope.changeLanguage = function(key){ $scope.currentLang = $scope.languages.filter(function(item){ return item.key === key; })[0]; $scope.showMenu = false; $translate.use(key) localStorage.setItem('preferredLanguage', key); } }] } } })()