I want to access a variable from my controller so I can use it in my service! I thought that if I made the variable global I could access it in my service, but it's not working out hehe. The variable is shops btw!
Here is where I'm creating the variable:
    $scope.$on('$ionicView.enter', function (e) {
    ecommercer.getData().then(function (s) {
        $scope.shops = s.vendors
        $scope.categories = s.categories
        $ionicScrollDelegate.resize()
        if ($stateParams.id && $stateParams.id.length > 1) {
            $ionicTabsDelegate.showBar(false)
            ecommercer.saveShopById($stateParams.id)
            $state.go('tab.ecommerce.shop')
        }
    })
})
Here (the same file) is where I'm using my variable:
    $scope.$watch('selectedCategory.name', function (newval, oldval) {
        if ($scope.selectedCategory.name != undefined) {
            $scope.shops = ecommercer.filterByCategory(newval.id)
        } else {
            $scope.shops = ecommercer.filterByCategory(null)
        }
    })
Here is where I create the same variable in my service file:
app.service('ecommercer', function (eapi, $q, storage, $http, endpointHandler, $state, $rootScope, $filter) {
var products, categories, vendors, shops
Finally, here is when I'm trying to use it in my service:
function filterByCategory(categoryid, shops) {
    if (!categoryid) return shops
    console.log(shops);
    var newlist = []
    for (var s in shops) {
        if (shops[s].category.split(',').length > 0) {
            for (var c in shops[s].category.split(',')) {
                if (shops[s].category.split(',')[c] == categoryid) {
                    newlist.push(shops[s])
                }
            }
        }
    } 
    return newlist
}
