I'm getting this weird url from Angular's $resource:
DELETE /dashboard/api/1.0/journalEntry?0=5&1=4&10=9&11=3&12=2&13=f&14=7&15=f&16=1&17=6&18=1&19=4&2=0&20=9&21=2&22=a&23=a&3=7&4=9&5=6&6=e&7=e&8=5&9=f
When what I'm really expecting is this:
DELETE /dashboard/api/1.0/journalEntry/540796ee5f932f7f161492aa
I've tried that URL and the server side appears to be working. It's a problem with the Angular Router Service.
Here's where I define the service:
'use strict';
angular.module('mean.dashboard')
.factory('JournalEntry', ['$resource',
function($resource){
return $resource('dashboard/api/1.0/journalEntry/:journalEntryId/', {
journalEntryId: '@_id'
}, {
update: {
method: 'PUT'
}
});
}
]);
And here's the controller where I call Resource:
$scope.editDeleteRow = function(item) {
console.log(item._id);
JournalEntry.remove(item._id).$promise.then(
function(response) {
$scope.addAlert('edit', 'Deleted', 'success');
//TODO remove item from client list
$scope.groupJournalEntries();
},
function(err) {
$scope.addAlert('add', 'Error ' + err.statusText, 'danger');
console.log(err);
}
);
};
What I miss?
I'm in a hurry so I didn't figure this one out all the way. It had something to do with @ not working the way I expected. I got it to work defining the service like this:
.factory('JournalEntry', ['$resource',
function($resource){
return $resource('dashboard/api/1.0/journalEntry/:journalEntryId', {
}, {
update: {
method: 'PUT'
}
});
}
]);
And calling it like this:
JournalEntry.remove({journalEntryId: item._id}).$promise.then(