### # Copyright (C) 2014 Andrey Antukh # Copyright (C) 2014 Jesús Espino Garcia # Copyright (C) 2014 David Barragán Merino # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU Affero General Public License as # published by the Free Software Foundation, either version 3 of the # License, or (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Affero General Public License for more details. # # You should have received a copy of the GNU Affero General Public License # along with this program. If not, see . # # File: modules/resources/issues.coffee ### taiga = @.taiga generateHash = taiga.generateHash resourceProvider = ($repo, $http, $urls, $storage, $q) -> service = {} hashSuffix = "issues-queryparams" filtersHashSuffix = "issues-filters" myFiltersHashSuffix = "issues-my-filters" service.get = (projectId, issueId) -> params = service.getQueryParams(projectId) params.project = projectId return $repo.queryOne("issues", issueId, params) service.list = (projectId, filters, options) -> params = {project: projectId} params = _.extend({}, params, filters or {}) service.storeQueryParams(projectId, params) return $repo.queryPaginated("issues", params, options) service.bulkCreate = (projectId, data) -> url = $urls.resolve("bulk-create-issues") params = {project_id: projectId, bulk_issues: data} return $http.post(url, params) service.stats = (projectId) -> return $repo.queryOneRaw("projects", "#{projectId}/issues_stats") service.filtersData = (projectId) -> return $repo.queryOneRaw("projects", "#{projectId}/issue_filters_data") service.listValues = (projectId, type) -> params = {"project": projectId} service.storeQueryParams(projectId, params) return $repo.queryMany(type, params) service.storeQueryParams = (projectId, params) -> ns = "#{projectId}:#{hashSuffix}" hash = generateHash([projectId, ns]) $storage.set(hash, params) service.getQueryParams = (projectId) -> ns = "#{projectId}:#{hashSuffix}" hash = generateHash([projectId, ns]) return $storage.get(hash) or {} service.storeFilters = (projectSlug, params) -> ns = "#{projectSlug}:#{filtersHashSuffix}" hash = generateHash([projectSlug, ns]) $storage.set(hash, params) service.getFilters = (projectSlug) -> ns = "#{projectSlug}:#{filtersHashSuffix}" hash = generateHash([projectSlug, ns]) return $storage.get(hash) or {} service.storeMyFilters = (projectId, myFilters) -> deferred = $q.defer() url = $urls.resolve("user-storage") ns = "#{projectId}:#{myFiltersHashSuffix}" hash = generateHash([projectId, ns]) if _.isEmpty(myFilters) promise = $http.delete("#{url}/#{hash}", {key: hash, value:myFilters}) promise.then -> deferred.resolve() promise.then null, -> deferred.reject() else promise = $http.put("#{url}/#{hash}", {key: hash, value:myFilters}) promise.then (data) -> deferred.resolve() promise.then null, (data) -> innerPromise = $http.post("#{url}", {key: hash, value:myFilters}) innerPromise.then -> deferred.resolve() innerPromise.then null, -> deferred.reject() return deferred.promise service.getMyFilters = (projectId) -> deferred = $q.defer() url = $urls.resolve("user-storage") ns = "#{projectId}:#{myFiltersHashSuffix}" hash = generateHash([projectId, ns]) promise = $http.get("#{url}/#{hash}") promise.then (data) -> deferred.resolve(data.data.value) promise.then null, (data) -> deferred.resolve({}) return deferred.promise return (instance) -> instance.issues = service module = angular.module("taigaResources") module.factory("$tgIssuesResourcesProvider", ["$tgRepo", "$tgHttp", "$tgUrls", "$tgStorage", "$q", resourceProvider])