taiga-front/app/coffee/modules/projects/main.coffee

261 lines
7.1 KiB
CoffeeScript

###
# Copyright (C) 2014 Andrey Antukh <niwi@niwi.be>
# Copyright (C) 2014 Jesús Espino Garcia <jespinog@gmail.com>
# Copyright (C) 2014 David Barragán Merino <bameda@dbarragan.com>
#
# 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 <http://www.gnu.org/licenses/>.
#
# File: modules/common/attachments.coffee
###
taiga = @.taiga
module = angular.module("taigaProject")
bindOnce = @.taiga.bindOnce
class ProjectsController extends taiga.Controller
@.$inject = [
"$scope",
"$q",
"$tgResources",
"$rootScope",
"$tgNavUrls",
"$tgAuth",
"$tgLocation",
"$appTitle",
"$projectUrl",
"tgLoader"
]
constructor: (@scope, @q, @rs, @rootscope, @navUrls, @auth, @location, @appTitle, @projectUrl,
tgLoader) ->
@appTitle.set("Projects")
if !@auth.isAuthenticated()
@location.path(@navUrls.resolve("login"))
@.user = @auth.getUser()
@.projects = []
promise = @.loadInitialData()
promise.then () =>
@scope.$emit("projects:loaded", @.projects)
promise.then null, @.onInitialDataError.bind(@)
# Finally
promise.finally tgLoader.pageLoaded
loadInitialData: ->
return @rs.projects.listByMember(@rootscope.user?.id).then (projects) =>
@.projects = {'recents': projects.slice(0, 8), 'all': projects}
for project in projects
project.url = @projectUrl.get(project)
return projects
newProject: ->
@rootscope.$broadcast("projects:create")
logout: ->
@auth.logout()
@location.path(@navUrls.resolve("login"))
module.controller("ProjectsController", ProjectsController)
class ProjectController extends taiga.Controller
@.$inject = [
"$scope",
"$tgResources",
"$tgRepo",
"$routeParams",
"$q",
"$rootScope",
"$appTitle",
"$tgLocation",
"$tgNavUrls"
]
constructor: (@scope, @rs, @repo, @params, @q, @rootscope, @appTitle, @location, @navUrls) ->
promise = @.loadInitialData()
promise.then () =>
@appTitle.set(@scope.project.name)
@scope.$emit("regenerate:project-pagination")
promise.then null, @.onInitialDataError.bind(@)
loadInitialData: ->
promise = @.loadProject()
promise.then(=> @.loadProjectStats())
return promise
loadProject: ->
return @rs.projects.getBySlug(@params.pslug).then (project) =>
@scope.projectId = project.id
@scope.project = project
@scope.$emit("project:loaded", @scope.project)
return project
loadProjectStats: ->
return @rs.projects.stats(@scope.projectId).then (stats) =>
@scope.stats = stats
return stats
module.controller("ProjectController", ProjectController)
ProjectsPaginationDirective = ($timeout) ->
link = ($scope, $el, $attrs) ->
prevBtn = $el.find(".v-pagination-previous")
nextBtn = $el.find(".v-pagination-next")
container = $el.find("ul")
pageSize = 0
containerSize = 0
render = ->
pageSize = $el.find(".v-pagination-list").height()
if container.find("li").length
if hasPagination()
if hasNextPage()
visible(nextBtn)
else
hide(nextBtn)
if hasPrevPage()
visible(prevBtn)
else
hide(prevBtn)
else
remove()
else
remove()
hasPagination = ->
containerSize = container.height()
return containerSize > pageSize
hasPrevPage = (top) ->
if !top?
top = -parseInt(container.css('top'), 10) || 0
return top != 0
hasNextPage = (top) ->
containerSize = container.height()
if !top
top = -parseInt(container.css('top'), 10) || 0
return containerSize > pageSize && top + pageSize < containerSize
nextPage = (callback) ->
top = parseInt(container.css('top'), 10)
newTop = top - pageSize
lastLi = $el.find(".v-pagination-list li:last-child")
maxTop = -((lastLi.position().top + lastLi.outerHeight()) - pageSize)
newTop = maxTop if newTop < maxTop
container.animate({"top": newTop}, callback)
return newTop
prevPage = (callback) ->
top = parseInt(container.css('top'), 10)
newTop = top + pageSize
newTop = 0 if newTop > 0
container.animate({"top": newTop}, callback)
return newTop
visible = (element) ->
element.css('visibility', 'visible')
hide = (element) ->
element.css('visibility', 'hidden')
checkButtonVisibility = () ->
remove = () ->
container.css('top', 0)
hide(prevBtn)
hide(nextBtn)
$el.on "click", ".v-pagination-previous", (event) ->
event.preventDefault()
if container.is(':animated')
return
visible(nextBtn)
newTop = prevPage()
if !hasPrevPage(newTop)
hide(prevBtn)
$el.on "click", ".v-pagination-next", (event) ->
event.preventDefault()
if container.is(':animated')
return
visible(prevBtn)
newTop = -nextPage()
if !hasNextPage(newTop)
hide(nextBtn)
$scope.$on "regenerate:project-pagination", ->
remove()
render()
$(window).on "resize.projects-pagination", render
$scope.$on "$destroy", ->
$(window).off "resize.projects-pagination"
return {
link: link
}
module.directive("tgProjectsPagination", ['$timeout', ProjectsPaginationDirective])
ProjectsListDirective = ($compile, $template) ->
template = $template.get('project/project-list.html', true)
link = ($scope, $el, $attrs, $ctrls) ->
render = (projects) ->
$el.html($compile(template({projects: projects}))($scope))
$scope.$emit("regenerate:project-pagination")
$scope.$on "projects:loaded", (ctx, projects) ->
render(projects.all) if projects.all?
return {
link: link
}
module.directive("tgProjectsList", ["$compile", "$tgTemplate", ProjectsListDirective])