kittu
kittu

Reputation: 7008

How to store values in $localStorage as object

I want to save all the objects in $localStorage as following:

$localStorage.userData.currentUser = data.name;
$localStorage.userData.devId= data.id;
$localStorage.userData.userRole = data.roles[0].name;
$localStorage.userData.userId = data.user_id;

controller Code:

myApp.controller('loginController', ['$rootScope', '$scope', 'Auth', '$state', '$localStorage',
    function ($rootScope, $scope, Auth, $state, $localStorage) {

        function successAuth(res) {
            $localStorage.token = res;
            $scope.currentUser = $localStorage.token.name;
            console.log("res: ", res);

            Auth.setUserData(res, function(){
                $scope.error = 'No User data available';
            });


            if ($localStorage.token) {
                $state.go("dashboard");
                $scope.isLogin = true;
            } else {
                alert("Invalid username or password");
            }
        }

        $scope.signin = function () {
            var formData = {device_id: myip, platform: "WEB", provider: "EMAIL", uid: $scope.login.username, access_token: "", password: $scope.login.password};
            Auth.signin(formData, successAuth, function () {
                $rootScope.error = 'Invalid credentials';
                console.log($rootScope.error);
            });
        };

        $scope.isLogin = !angular.isUndefined($localStorage.token);
    }]);

I tried the following according to docs but didn't work. Its giving error saying '$storage' of undefined

$scope.$storage = $localStorage;

$storage.userData.currentUser = data.name;
$storage.userData.devId= data.id;
$storage.userData.userRole = data.roles[0].name;
$storage.userData.userId = data.user_id;

How do I save all data in to $localStorage as above ?

Upvotes: 0

Views: 1245

Answers (3)

AllJs
AllJs

Reputation: 1810

In loginController, inject $window instead of $localStorage and use $window.localStorage.getItem(...) or even $window.localStorage["storage_name"].
To store/set data in localStorage, you could do $window.localStorage['storage_name'] = angular.toJson( object_to_store);

Upvotes: 0

Mahendra Kulkarni
Mahendra Kulkarni

Reputation: 1507

here is my code, try this one:

 localStorage.setItem('user', JSON.stringify({
   name: "xyz",
   age: 25,
   comp: "abc"
 }));
 user = JSON.parse(localStorage.getItem('user'));
 console.log(localStorage)

Upvotes: 0

Hitesh Balar
Hitesh Balar

Reputation: 181

You could try something like

var newData = {
    currentUser : data.name,
    devId : data.id,
    userRole : data.roles[0].name,
    userId : data.user_id
 };

 localStorage.setItem( 'data' , JSON.stringify(newData) );

Can Parse // For each item in local storage...

 for( item in localStorage ) {

        // Parse the JSON string and add to to array
        var newItem = JSON.parse( localStorage[item] );
        $scope.data.push( newItem );

    }

Get data by its key

localStorage.getItem( 'data' );

Upvotes: 2

Related Questions