2018-11-21 11:08:53 +01:00
|
|
|
'use strict';
|
2015-05-05 03:10:25 +02:00
|
|
|
|
2020-05-27 18:49:53 +02:00
|
|
|
Application.Services.factory('Member', ['$resource', 'Setting', function ($resource, Setting) {
|
2018-11-27 15:16:23 +01:00
|
|
|
return $resource('/api/members/:id',
|
2018-10-25 16:51:20 +02:00
|
|
|
{ id: '@id' }, {
|
|
|
|
update: {
|
|
|
|
method: 'PUT'
|
|
|
|
},
|
|
|
|
lastSubscribed: {
|
|
|
|
method: 'GET',
|
|
|
|
url: '/api/last_subscribed/:limit',
|
|
|
|
params: { limit: '@limit' },
|
|
|
|
isArray: true
|
|
|
|
},
|
|
|
|
merge: {
|
|
|
|
method: 'PUT',
|
|
|
|
url: '/api/members/:id/merge'
|
|
|
|
},
|
|
|
|
list: {
|
|
|
|
url: '/api/members/list',
|
|
|
|
method: 'POST',
|
|
|
|
isArray: true
|
|
|
|
},
|
|
|
|
search: {
|
|
|
|
method: 'GET',
|
|
|
|
url: '/api/members/search/:query',
|
|
|
|
params: { query: '@query' },
|
|
|
|
isArray: true
|
|
|
|
},
|
|
|
|
mapping: {
|
|
|
|
method: 'GET',
|
|
|
|
url: '/api/members/mapping'
|
2020-02-18 17:36:45 +01:00
|
|
|
},
|
|
|
|
completeTour: {
|
|
|
|
method: 'PATCH',
|
|
|
|
url: '/api/members/:id/complete_tour',
|
2020-02-25 18:02:41 +01:00
|
|
|
params: { id: '@id' },
|
2020-03-02 11:17:28 +01:00
|
|
|
interceptor: {
|
|
|
|
response: function (response) {
|
2020-05-27 18:49:53 +02:00
|
|
|
return Setting.query({ names: "['feature_tour_display']" }).$promise.then((settings) => {
|
|
|
|
if (settings.feature_tour_display === 'session') {
|
|
|
|
Fablab.sessionTours.push(response.data.tours[0]);
|
|
|
|
return { tours: Fablab.sessionTours };
|
|
|
|
}
|
|
|
|
return response.data;
|
|
|
|
});
|
2020-03-02 11:17:28 +01:00
|
|
|
}
|
2020-02-25 18:02:41 +01:00
|
|
|
}
|
2020-05-04 18:32:25 +02:00
|
|
|
},
|
|
|
|
updateRole: {
|
|
|
|
method: 'PATCH',
|
|
|
|
url: '/api/members/:id/update_role'
|
2018-10-25 16:51:20 +02:00
|
|
|
}
|
2018-10-25 16:50:16 +02:00
|
|
|
}
|
2018-11-27 15:16:23 +01:00
|
|
|
);
|
|
|
|
}]);
|