Lateral navigation for projects refactor, now it's an only directive
parent
779151efde
commit
ea1156af2d
|
@ -29,9 +29,9 @@ module = angular.module("taigaNavMenu", [])
|
||||||
## Projects Navigation
|
## Projects Navigation
|
||||||
#############################################################################
|
#############################################################################
|
||||||
class ProjectsNavigationController extends taiga.Controller
|
class ProjectsNavigationController extends taiga.Controller
|
||||||
@.$inject = ["$scope", "$tgResources", "$tgNavUrls"]
|
@.$inject = ["$scope", "$rootScope", "$tgResources", "$tgNavUrls"]
|
||||||
|
|
||||||
constructor: (@scope, @rs, @navurls) ->
|
constructor: (@scope, @rootscope, @rs, @navurls) ->
|
||||||
promise = @.loadInitialData()
|
promise = @.loadInitialData()
|
||||||
promise.then null, ->
|
promise.then null, ->
|
||||||
console.log "FAIL"
|
console.log "FAIL"
|
||||||
|
@ -39,7 +39,6 @@ class ProjectsNavigationController extends taiga.Controller
|
||||||
|
|
||||||
loadInitialData: ->
|
loadInitialData: ->
|
||||||
return @rs.projects.list().then (projects) =>
|
return @rs.projects.list().then (projects) =>
|
||||||
@scope.projects = projects
|
|
||||||
for project in projects
|
for project in projects
|
||||||
if project.is_backlog_activated and project.my_permissions.indexOf("view_us")>-1
|
if project.is_backlog_activated and project.my_permissions.indexOf("view_us")>-1
|
||||||
url = @navurls.resolve("project-backlog")
|
url = @navurls.resolve("project-backlog")
|
||||||
|
@ -53,12 +52,64 @@ class ProjectsNavigationController extends taiga.Controller
|
||||||
url = @navurls.resolve("project")
|
url = @navurls.resolve("project")
|
||||||
|
|
||||||
project.url = @navurls.formatUrl(url, {'project': project.slug})
|
project.url = @navurls.formatUrl(url, {'project': project.slug})
|
||||||
|
|
||||||
|
@scope.projects = projects
|
||||||
|
@scope.filteredProjects = projects
|
||||||
|
@scope.filterText = ""
|
||||||
return projects
|
return projects
|
||||||
|
|
||||||
|
newProject: ->
|
||||||
|
@rootscope.$broadcast("projects:create")
|
||||||
|
|
||||||
|
filterProjects: (text) ->
|
||||||
|
@scope.filteredProjects = _.filter(@scope.projects, (project) -> project.name.toLowerCase().indexOf(text) > -1)
|
||||||
|
@scope.filterText = text
|
||||||
|
@rootscope.$broadcast("projects:filtered")
|
||||||
|
|
||||||
|
module.controller("ProjectsNavigationController", ProjectsNavigationController)
|
||||||
|
|
||||||
|
|
||||||
|
ProjectsNavigationDirective = ($rootscope, animationFrame, $timeout) ->
|
||||||
|
baseTemplate = _.template("""
|
||||||
|
<h1>Your projects</h1>
|
||||||
|
<form>
|
||||||
|
<fieldset>
|
||||||
|
<!--TODO-->
|
||||||
|
<input type="text" placeholder="Search in..." class="search-project"/>
|
||||||
|
<a class="icon icon-search"></a>
|
||||||
|
</fieldset>
|
||||||
|
</form>
|
||||||
|
|
||||||
|
<div class="create-project-button">
|
||||||
|
<a class="button button-green" href="">
|
||||||
|
Create project
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="projects-pagination">
|
||||||
|
<a class="v-pagination-previous icon icon-arrow-up " href=""></a>
|
||||||
|
<div class="v-pagination-list">
|
||||||
|
<ul class="projects-list">
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
<a class="v-pagination-next icon icon-arrow-bottom" href=""></a>
|
||||||
|
</div>
|
||||||
|
""") # TODO: i18n
|
||||||
|
|
||||||
|
projectsTemplate = _.template("""
|
||||||
|
<% _.each(projects, function(project) { %>
|
||||||
|
<li>
|
||||||
|
<a href="<%- project.url %>">
|
||||||
|
<%- project.name %>
|
||||||
|
<span class="icon icon-arrow-right"/>
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<% }) %>
|
||||||
|
""") # TODO: i18n
|
||||||
|
|
||||||
ProjectsNavigationDirective = ($rootscope, animationFrame) ->
|
|
||||||
overlay = $(".projects-nav-overlay")
|
overlay = $(".projects-nav-overlay")
|
||||||
loadingStart = 0
|
loadingStart = 0
|
||||||
|
|
||||||
hideMenu = () ->
|
hideMenu = () ->
|
||||||
if overlay.is(':visible')
|
if overlay.is(':visible')
|
||||||
difftime = new Date().getTime() - loadingStart
|
difftime = new Date().getTime() - loadingStart
|
||||||
|
@ -75,7 +126,18 @@ ProjectsNavigationDirective = ($rootscope, animationFrame) ->
|
||||||
.removeClass("loading-project open-projects-nav")
|
.removeClass("loading-project open-projects-nav")
|
||||||
), timeout
|
), timeout
|
||||||
|
|
||||||
|
renderProjects = ($el, projects) ->
|
||||||
|
html = projectsTemplate({projects: projects})
|
||||||
|
$el.find(".projects-list").html(html)
|
||||||
|
|
||||||
|
render = ($el, projects) ->
|
||||||
|
html = baseTemplate()
|
||||||
|
$el.html(html)
|
||||||
|
renderProjects($el, projects)
|
||||||
|
|
||||||
link = ($scope, $el, $attrs, $ctrl) ->
|
link = ($scope, $el, $attrs, $ctrl) ->
|
||||||
|
$ctrl = $el.controller()
|
||||||
|
|
||||||
$rootscope.$on("project:loaded", hideMenu)
|
$rootscope.$on("project:loaded", hideMenu)
|
||||||
|
|
||||||
overlay.on 'click', () ->
|
overlay.on 'click', () ->
|
||||||
|
@ -95,13 +157,96 @@ ProjectsNavigationDirective = ($rootscope, animationFrame) ->
|
||||||
|
|
||||||
loadingStart = new Date().getTime()
|
loadingStart = new Date().getTime()
|
||||||
|
|
||||||
|
$el.on "click", ".create-project-button .button", (event) ->
|
||||||
|
event.preventDefault()
|
||||||
|
$ctrl.newProject()
|
||||||
|
|
||||||
|
$el.on "keyup", ".search-project", (event) ->
|
||||||
|
target = angular.element(event.currentTarget)
|
||||||
|
$ctrl.filterProjects(target.val())
|
||||||
|
|
||||||
|
$scope.$watch "projects", (projects) ->
|
||||||
|
render($el, $scope.projects) if projects?
|
||||||
|
|
||||||
|
bindOnce $scope, "projects", (projects) ->
|
||||||
|
prevBtn = $el.find(".v-pagination-previous")
|
||||||
|
nextBtn = $el.find(".v-pagination-next")
|
||||||
|
container = $el.find("ul")
|
||||||
|
pageSize = 0
|
||||||
|
containerSize = 0
|
||||||
|
|
||||||
|
nextPage = (element, pageSize, callback) ->
|
||||||
|
top = parseInt(element.css('top'), 10)
|
||||||
|
newTop = top - pageSize
|
||||||
|
|
||||||
|
element.animate({"top": newTop}, callback);
|
||||||
|
|
||||||
|
return newTop
|
||||||
|
|
||||||
|
prevPage = (element, pageSize, callback) ->
|
||||||
|
top = parseInt(element.css('top'), 10)
|
||||||
|
newTop = top + pageSize
|
||||||
|
|
||||||
|
element.animate({"top": newTop}, callback);
|
||||||
|
|
||||||
|
return newTop
|
||||||
|
|
||||||
|
visible = (element) ->
|
||||||
|
element.css('visibility', 'visible')
|
||||||
|
|
||||||
|
hide = (element) ->
|
||||||
|
element.css('visibility', 'hidden')
|
||||||
|
|
||||||
|
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(container, pageSize)
|
||||||
|
|
||||||
|
if newTop == 0
|
||||||
|
hide(prevBtn)
|
||||||
|
|
||||||
|
$el.on "click", ".v-pagination-next", (event) ->
|
||||||
|
event.preventDefault()
|
||||||
|
|
||||||
|
if container.is(':animated')
|
||||||
|
return
|
||||||
|
|
||||||
|
visible(prevBtn)
|
||||||
|
|
||||||
|
newTop = nextPage(container, pageSize)
|
||||||
|
|
||||||
|
if -newTop + pageSize > containerSize
|
||||||
|
hide(nextBtn)
|
||||||
|
|
||||||
|
$scope.$on "projects:filtered", ->
|
||||||
|
renderProjects($el, $scope.filteredProjects)
|
||||||
|
#wait digest end
|
||||||
|
$timeout () ->
|
||||||
|
if $scope.filteredProjects
|
||||||
|
pageSize = $el.find(".v-pagination-list").height()
|
||||||
|
containerSize = container.height()
|
||||||
|
if containerSize > pageSize
|
||||||
|
visible(nextBtn)
|
||||||
|
else
|
||||||
|
remove()
|
||||||
|
else
|
||||||
|
remove()
|
||||||
|
|
||||||
return {
|
return {
|
||||||
link: link
|
link: link
|
||||||
controller: ProjectsNavigationController
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
module.directive("tgProjectsNav", ["$rootScope", "animationFrame", "$timeout", ProjectsNavigationDirective])
|
||||||
module.directive("tgProjectsNav", ["$rootScope", "animationFrame", ProjectsNavigationDirective])
|
|
||||||
|
|
||||||
|
|
||||||
#############################################################################
|
#############################################################################
|
||||||
|
|
|
@ -1,15 +1,6 @@
|
||||||
taiga = @.taiga
|
taiga = @.taiga
|
||||||
module = angular.module("taigaProject")
|
module = angular.module("taigaProject")
|
||||||
|
|
||||||
class ProjectNavController extends taiga.Controller
|
|
||||||
@.$inject = ["$rootScope"]
|
|
||||||
|
|
||||||
constructor: (@rootscope) ->
|
|
||||||
|
|
||||||
newProject: ->
|
|
||||||
@rootscope.$broadcast("projects:create")
|
|
||||||
|
|
||||||
module.controller("ProjectNavController", ProjectNavController)
|
|
||||||
|
|
||||||
class ProjectsController extends taiga.Controller
|
class ProjectsController extends taiga.Controller
|
||||||
@.$inject = ["$scope", "$tgResources", "$rootScope", "$tgNavUrls", "$tgAuth", "$location", "$appTitle"]
|
@.$inject = ["$scope", "$tgResources", "$rootScope", "$tgNavUrls", "$tgAuth", "$location", "$appTitle"]
|
||||||
|
@ -82,94 +73,3 @@ class ProjectController extends taiga.Controller
|
||||||
|
|
||||||
|
|
||||||
module.controller("ProjectController", ProjectController)
|
module.controller("ProjectController", ProjectController)
|
||||||
|
|
||||||
ProjectsPaginationDirective = ($timeout) ->
|
|
||||||
nextPage = (element, pageSize, callback) ->
|
|
||||||
top = parseInt(element.css('top'), 10)
|
|
||||||
newTop = top - pageSize
|
|
||||||
|
|
||||||
element.animate({"top": newTop}, callback)
|
|
||||||
|
|
||||||
return newTop
|
|
||||||
|
|
||||||
prevPage = (element, pageSize, callback) ->
|
|
||||||
top = parseInt(element.css('top'), 10)
|
|
||||||
newTop = top + pageSize
|
|
||||||
|
|
||||||
element.animate({"top": newTop}, callback)
|
|
||||||
|
|
||||||
return newTop
|
|
||||||
|
|
||||||
visible = (element) ->
|
|
||||||
element.css('visibility', 'visible')
|
|
||||||
|
|
||||||
hide = (element) ->
|
|
||||||
element.css('visibility', 'hidden')
|
|
||||||
|
|
||||||
link = ($scope, $el, $attrs) ->
|
|
||||||
prevBtn = $el.find(".v-pagination-previous")
|
|
||||||
nextBtn = $el.find(".v-pagination-next")
|
|
||||||
container = $el.find("ul")
|
|
||||||
|
|
||||||
pageSize = 0
|
|
||||||
containerSize = 0
|
|
||||||
|
|
||||||
remove = () ->
|
|
||||||
container.css('top', 0)
|
|
||||||
hide(prevBtn)
|
|
||||||
hide(nextBtn)
|
|
||||||
|
|
||||||
prevBtn.on "click", (event) ->
|
|
||||||
event.preventDefault()
|
|
||||||
|
|
||||||
if container.is(':animated')
|
|
||||||
return
|
|
||||||
|
|
||||||
visible(nextBtn)
|
|
||||||
|
|
||||||
newTop = prevPage(container, pageSize)
|
|
||||||
|
|
||||||
if newTop == 0
|
|
||||||
hide(prevBtn)
|
|
||||||
|
|
||||||
nextBtn.on "click", (event) ->
|
|
||||||
event.preventDefault()
|
|
||||||
|
|
||||||
if container.is(':animated')
|
|
||||||
return
|
|
||||||
|
|
||||||
visible(prevBtn)
|
|
||||||
|
|
||||||
newTop = nextPage(container, pageSize)
|
|
||||||
|
|
||||||
if -newTop + pageSize > containerSize
|
|
||||||
hide(nextBtn)
|
|
||||||
|
|
||||||
$scope.$watch 'active', () ->
|
|
||||||
#wait digest end
|
|
||||||
$timeout () ->
|
|
||||||
if $scope.active
|
|
||||||
pageSize = $el.find(".v-pagination-list").height()
|
|
||||||
containerSize = container.height()
|
|
||||||
|
|
||||||
if containerSize > pageSize
|
|
||||||
visible(nextBtn)
|
|
||||||
else
|
|
||||||
remove()
|
|
||||||
else
|
|
||||||
remove()
|
|
||||||
|
|
||||||
return {
|
|
||||||
scope: {
|
|
||||||
active: '='
|
|
||||||
},
|
|
||||||
link: link,
|
|
||||||
transclude: true,
|
|
||||||
template: """
|
|
||||||
<a class="v-pagination-previous icon icon-arrow-up " href=""></a>
|
|
||||||
<div class="v-pagination-list" ng-transclude=""></div>
|
|
||||||
<a class="v-pagination-next icon icon-arrow-bottom" href=""></a>
|
|
||||||
"""
|
|
||||||
}
|
|
||||||
|
|
||||||
module.directive("tgProjectsPagination", ['$timeout', ProjectsPaginationDirective])
|
|
||||||
|
|
|
@ -6,18 +6,4 @@
|
||||||
div.lightbox.lightbox_create-project.hidden(tg-lb-create-project)
|
div.lightbox.lightbox_create-project.hidden(tg-lb-create-project)
|
||||||
include lightbox_create-project
|
include lightbox_create-project
|
||||||
|
|
||||||
nav.projects-nav(ng-controller="ProjectNavController as ctrl", tg-projects-nav)
|
nav.projects-nav(ng-controller="ProjectsNavigationController", tg-projects-nav)
|
||||||
h1 Your projects
|
|
||||||
form
|
|
||||||
fieldset
|
|
||||||
input(type="text" placeholder="Search in...", ng-model="projectsSearch.$")
|
|
||||||
a.icon.icon-search
|
|
||||||
|
|
||||||
.create-project-button
|
|
||||||
a.button.button-green(href="", ng-click="ctrl.newProject()") Create project
|
|
||||||
|
|
||||||
div.projects-pagination(tg-projects-pagination, active="projects.length && !projectsSearch.$.length")
|
|
||||||
ul.projects-list
|
|
||||||
li(ng-repeat="project in projects|filter:projectsSearch:strict track by project.id")
|
|
||||||
a(href="", tg-bo-bind="project.name", ng-href="{{ project.url }}")
|
|
||||||
span.icon.icon-arrow-right
|
|
||||||
|
|
Loading…
Reference in New Issue