overleaf/services/web/public/coffee/directives/selectAll.coffee

82 lines
2 KiB
CoffeeScript
Raw Normal View History

2014-07-08 11:02:26 +00:00
define [
"base"
], (App) ->
App.directive "selectAllList", () ->
return {
controller: ["$scope", ($scope) ->
# Selecting or deselecting all should apply to all projects
2015-06-29 12:43:34 +00:00
@selectAll = () ->
2014-07-08 11:02:26 +00:00
$scope.$broadcast "select-all:select"
2015-06-29 12:43:34 +00:00
@deselectAll = () ->
2014-07-08 11:02:26 +00:00
$scope.$broadcast "select-all:deselect"
2015-06-29 12:43:34 +00:00
@clearSelectAllState = () ->
2014-07-08 11:02:26 +00:00
$scope.$broadcast "select-all:clear"
return
2014-07-08 11:02:26 +00:00
]
link: (scope, element, attrs) ->
}
App.directive "selectAll", () ->
return {
require: "^selectAllList"
link: (scope, element, attrs, selectAllListController) ->
scope.$on "select-all:clear", () ->
element.prop("checked", false)
element.change () ->
if element.is(":checked")
selectAllListController.selectAll()
else
selectAllListController.deselectAll()
return true
}
App.directive "selectIndividual", () ->
return {
require: "^selectAllList"
scope: {
ngModel: "="
}
link: (scope, element, attrs, selectAllListController) ->
ignoreChanges = false
scope.$watch "ngModel", (value) ->
if value? and !ignoreChanges
selectAllListController.clearSelectAllState()
scope.$on "select-all:select", () ->
return if element.prop('disabled')
2014-07-08 11:02:26 +00:00
ignoreChanges = true
scope.$apply () ->
scope.ngModel = true
ignoreChanges = false
scope.$on "select-all:deselect", () ->
return if element.prop('disabled')
2014-07-08 11:02:26 +00:00
ignoreChanges = true
scope.$apply () ->
scope.ngModel = false
ignoreChanges = false
2017-05-01 16:11:03 +00:00
scope.$on "select-all:row-clicked", () ->
return if element.prop('disabled')
2017-05-01 16:11:03 +00:00
ignoreChanges = true
scope.$apply () ->
scope.ngModel = !scope.ngModel
if !scope.ngModel
selectAllListController.clearSelectAllState()
2017-05-01 16:11:03 +00:00
ignoreChanges = false
}
App.directive "selectRow", () ->
return {
scope: true
link: (scope, element, attrs) ->
element.on "click", (e) ->
scope.$broadcast "select-all:row-clicked"
}