(function () { 'use strict'; var serviceId = 'emailTemplatesDataContext'; angular.module('emailTemplates').factory(serviceId, ['$q', '$http', 'emailTemplatesConfig', '$modal', datacontext]); function datacontext($q, $http, config, $modal) { var service = { getEmailTemplate: getEmailTemplate, getEmailTemplates: getEmailTemplates, createEmailTemplate: createEmailTemplate, deleteEmailTemplate: deleteEmailTemplate }; return service; function handleError(response) { // The API response from the server should be returned in a // nomralized format. However, if the request was not handled by the // server (or what not handles properly - ex. server error), then we // may have to normalize it on our end, as best we can. if ( !angular.isObject(response.data) || !response.data.message ) { return ($q.reject("An unknown error occurred.")); } // Otherwise, use expected error message. return ($q.reject(response.data.message)); } // I transform the successful response, unwrapping the application data // from the API response payload. function handleSuccess(response) { return (response.data); } function getEmailTemplates(organisationId, appcode) { var request = $http({ method: "get", url: config.myusersUrl + 'api/organisations/' + organisationId + '/emailTemplates/' + appcode }); return (request.then(handleSuccess, handleError)); } function createEmailTemplate(template) { var request = $http({ method: "post", url: config.myusersUrl + 'api/organisations/emailTemplates', data: template }); return (request.then(handleSuccess, handleError)); } function deleteEmailTemplate(id) { var request = $http({ method: "post", url: config.myusersUrl + 'api/organisations/emailTemplates/Delete/' + id }); return (request.then(handleSuccess, handleError)); } function getEmailTemplate(id) { var request = $http({ method: "get", url: config.myusersUrl + 'api/organisations/' + id + '/emailTemplate' }); return (request.then(handleSuccess, handleError)); } } })();