Update UsStatus directive

stable
David Barragán Merino 2014-06-26 13:48:51 +02:00
parent d71d1f2594
commit 2c9a809df9
3 changed files with 82 additions and 16 deletions

View File

@ -21,6 +21,7 @@
taiga = @.taiga taiga = @.taiga
mixOf = @.taiga.mixOf mixOf = @.taiga.mixOf
groupBy = @.taiga.groupBy
module = angular.module("taigaTaskboard", []) module = angular.module("taigaTaskboard", [])
@ -76,6 +77,8 @@ class TaskboardController extends mixOf(taiga.Controller, taiga.PageMixin)
@scope.points = _.sortBy(project.points, "order") @scope.points = _.sortBy(project.points, "order")
@scope.taskStatusList = _.sortBy(project.task_statuses, "order") @scope.taskStatusList = _.sortBy(project.task_statuses, "order")
@scope.usStatusList = _.sortBy(project.us_statuses, "order") @scope.usStatusList = _.sortBy(project.us_statuses, "order")
@scope.usStatusById = groupBy(project.us_statuses, (e) -> e.id)
return project return project
loadTaskboard: -> loadTaskboard: ->
@ -96,6 +99,7 @@ class TaskboardController extends mixOf(taiga.Controller, taiga.PageMixin)
module.controller("TaskboardController", TaskboardController) module.controller("TaskboardController", TaskboardController)
############################################################################# #############################################################################
## TaskboardDirective ## TaskboardDirective
############################################################################# #############################################################################
@ -119,9 +123,11 @@ TaskboardDirective = ->
return {link: link} return {link: link}
# TODO: the name of this directive should be changet #############################################################################
# to more apropiate, like: TaskboardRowsizeFixer ## Task Row Size Fixer Directive
TaskboardTaskrowDirective = -> #############################################################################
TaskboardRowSizeFixer = ->
link = ($scope, $el, $attrs) -> link = ($scope, $el, $attrs) ->
taiga.bindOnce $scope, "taskStatusList", (statuses) -> taiga.bindOnce $scope, "taskStatusList", (statuses) ->
itemSize = 300 + (10 * statuses.length) itemSize = 300 + (10 * statuses.length)
@ -131,16 +137,71 @@ TaskboardTaskrowDirective = ->
return {link: link} return {link: link}
UsStatusDirective = -> #############################################################################
link = ($scope, $el, $attrs) -> ## User story status directive
$scope.$watch "#{$attrs.tgTaskboardUsStatus}.status", (status_id) -> #############################################################################
if status_id is undefined
return TaskboardUsStatusDirective = ($repo) ->
status_name = $scope.usStatusList[status_id].name # NOTE: This directive is similar to backlog.main.UsStatusDirective
$el.html(status_name) selectionTemplate = _.template("""
<ul class="popover pop-status">
<% _.forEach(statuses, function(status) { %>
<li>
<a href="" class="status" title="<%- status.name %>" data-status-id="<%- status.id %>">
<%- status.name %>
</a>
</li>
<% }); %>
</ul>
""")
updateUsStatus = ($el, us, usStatusById) ->
usStatusDom = $el.find(".us-status")
usStatusDom.text(usStatusById[us.status].name)
usStatusDom.css('color', usStatusById[us.status].color)
link = ($scope, $el, $attrs) ->
$ctrl = $el.controller()
us = $scope.$eval($attrs.tgTaskboardUsStatus)
taiga.bindOnce $scope, "project", (project) ->
$el.append(selectionTemplate({ 'statuses': project.us_statuses }))
updateUsStatus($el, us, $scope.usStatusById)
$el.on "click", ".us-status", (event) ->
event.preventDefault()
event.stopPropagation()
$el.find(".pop-status").show()
body = angular.element("body")
body.one "click", (event) ->
$el.find(".popover").hide()
$el.on "click", ".status", (event) ->
event.preventDefault()
event.stopPropagation()
target = angular.element(event.currentTarget)
us.status = target.data("status-id")
$el.find(".pop-status").hide()
updateUsStatus($el, us, $scope.usStatusById)
$scope.$apply () ->
$repo.save(us).then ->
$ctrl.loadSprintStats()
$scope.$on "$destroy", ->
$el.off()
return {link: link}
#############################################################################
## User story status directive
#############################################################################
TaskboardUsPointsDirective = ($repo) ->
return {link:link}
module.directive("tgTaskboard", TaskboardDirective) module.directive("tgTaskboard", TaskboardDirective)
module.directive("tgTaskboardTaskrow", TaskboardTaskrowDirective) module.directive("tgTaskboardRowSizeFixer", TaskboardRowSizeFixer)
module.directive("tgTaskboardUsStatus", UsStatusDirective) module.directive("tgTaskboardUsStatus", ["$tgRepo", TaskboardUsStatusDirective])

View File

@ -1,6 +1,6 @@
div.taskboard-table div.taskboard-table
div.taskboard-table-header div.taskboard-table-header
div.taskboard-table-inner(tg-taskboard-taskrow) div.taskboard-table-inner(tg-taskboard-row-size-fixer)
h2.task-colum_name "User story" h2.task-colum_name "User story"
h2.task-colum_name(ng-repeat="s in taskStatusList track by s.id", tg-bo-html="s.name") h2.task-colum_name(ng-repeat="s in taskStatusList track by s.id", tg-bo-html="s.name")
div.taskboard-table-body div.taskboard-table-body
@ -12,7 +12,8 @@ div.taskboard-table
h3.us-title h3.us-title
span.us-ref(tg-bo-ref="us.ref") span.us-ref(tg-bo-ref="us.ref")
span(ng-bind="us.subject") span(ng-bind="us.subject")
div.us-status(tg-taskboard-us-status="us") div.status(tg-taskboard-us-status="us")
a.us-status(href="", title="Status Name")
ul.points-list ul.points-list
li UX li UX
span 4.5 span 4.5

View File

@ -70,9 +70,13 @@ $column-margin: 0 10px 0 0;
color: $gray; color: $gray;
margin-right: .5rem; margin-right: .5rem;
} }
.us-status { .status {
color: $green-taiga; color: $green-taiga;
margin-bottom: .5rem; margin-bottom: .5rem;
position: relative;
}
.pop-status {
@include popover(150px, 20px, 30px, '', '');
} }
.points-list { .points-list {
span { span {