248 lines
7.7 KiB
CoffeeScript
248 lines
7.7 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/base/confirm.coffee
|
|
###
|
|
|
|
taiga = @.taiga
|
|
timeout = @.taiga.timeout
|
|
cancelTimeout = @.taiga.cancelTimeout
|
|
debounce = @.taiga.debounce
|
|
bindMethods = @.taiga.bindMethods
|
|
|
|
NOTIFICATION_MSG = {
|
|
"success":
|
|
title: "Everything is ok"
|
|
message: "Our Oompa Loompas saved all your changes!"
|
|
"error":
|
|
title: "Oops, something happened..."
|
|
message: "Our Oompa Loompas are sad, your changes were not saved!"
|
|
"light-error":
|
|
title: "Oops, something happened..."
|
|
message: "Our Oompa Loompas are sad, your changes were not saved!"
|
|
}
|
|
|
|
|
|
class ConfirmService extends taiga.Service
|
|
@.$inject = ["$q", "lightboxService", "$tgLoading"]
|
|
|
|
constructor: (@q, @lightboxService, @loading) ->
|
|
bindMethods(@)
|
|
|
|
hide: (el)->
|
|
if el
|
|
@lightboxService.close(el)
|
|
|
|
el.off(".confirm-dialog")
|
|
|
|
ask: (title, subtitle, message, lightboxSelector=".lightbox-generic-ask") ->
|
|
el = angular.element(lightboxSelector)
|
|
|
|
# Render content
|
|
el.find("h2.title").html(title)
|
|
el.find("span.subtitle").html(subtitle)
|
|
el.find("span.message").html(message)
|
|
|
|
defered = @q.defer()
|
|
|
|
# Assign event handlers
|
|
el.on "click.confirm-dialog", "a.button-green", debounce 2000, (event) =>
|
|
event.preventDefault()
|
|
target = angular.element(event.currentTarget)
|
|
@loading.start(target)
|
|
defered.resolve (ok=true) =>
|
|
@loading.finish(target)
|
|
if ok
|
|
@.hide(el)
|
|
|
|
el.on "click.confirm-dialog", "a.button-red", (event) =>
|
|
event.preventDefault()
|
|
defered.reject()
|
|
@.hide(el)
|
|
|
|
@lightboxService.open(el)
|
|
|
|
return defered.promise
|
|
|
|
askOnDelete: (title, message) ->
|
|
return @.ask(title, "Are you sure you want to delete?", message) #TODO: i18n
|
|
|
|
askChoice: (title, subtitle, choices, replacement, warning, lightboxSelector=".lightbox-ask-choice") ->
|
|
el = angular.element(lightboxSelector)
|
|
|
|
# Render content
|
|
el.find(".title").html(title)
|
|
el.find(".subtitle").html(subtitle)
|
|
|
|
if replacement
|
|
el.find(".replacement").html(replacement)
|
|
else
|
|
el.find(".replacement").remove()
|
|
|
|
if warning
|
|
el.find(".warning").html(warning)
|
|
else
|
|
el.find(".warning").remove()
|
|
|
|
choicesField = el.find(".choices")
|
|
choicesField.html('')
|
|
_.each choices, (value, key) ->
|
|
choicesField.append(angular.element("<option value='#{key}'>#{value}</option>"))
|
|
defered = @q.defer()
|
|
|
|
# Assign event handlers
|
|
el.on "click.confirm-dialog", "a.button-green", debounce 2000, (event) =>
|
|
event.preventDefault()
|
|
target = angular.element(event.currentTarget)
|
|
@loading.start(target)
|
|
defered.resolve {
|
|
selected: choicesField.val()
|
|
finish: =>
|
|
@loading.finish(target)
|
|
@.hide(el)
|
|
}
|
|
|
|
el.on "click.confirm-dialog", "a.button-red", (event) =>
|
|
event.preventDefault()
|
|
defered.reject()
|
|
@.hide(el)
|
|
|
|
@lightboxService.open(el)
|
|
|
|
return defered.promise
|
|
|
|
error: (message) ->
|
|
el = angular.element(".lightbox-generic-error")
|
|
|
|
# Render content
|
|
el.find("h2.title").html(message)
|
|
defered = @q.defer()
|
|
|
|
# Assign event handlers
|
|
el.on "click.confirm-dialog", "a.button-green", (event) =>
|
|
event.preventDefault()
|
|
defered.resolve()
|
|
@.hide(el)
|
|
|
|
el.on "click.confirm-dialog", "a.close", (event) =>
|
|
event.preventDefault()
|
|
defered.resolve()
|
|
@.hide(el)
|
|
|
|
@lightboxService.open(el)
|
|
|
|
return defered.promise
|
|
|
|
success: (title, message) ->
|
|
el = angular.element(".lightbox-generic-success")
|
|
|
|
# Render content
|
|
el.find("h2.title").html(title) if title
|
|
el.find("p.message").html(message) if message
|
|
defered = @q.defer()
|
|
|
|
# Assign event handlers
|
|
el.on "click.confirm-dialog", "a.button-green", (event) =>
|
|
event.preventDefault()
|
|
defered.resolve()
|
|
@.hide(el)
|
|
|
|
el.on "click.confirm-dialog", "a.close", (event) =>
|
|
event.preventDefault()
|
|
defered.resolve()
|
|
@.hide(el)
|
|
|
|
@lightboxService.open(el)
|
|
|
|
return defered.promise
|
|
|
|
loader: (title, message) ->
|
|
el = angular.element(".lightbox-generic-loading")
|
|
|
|
# Render content
|
|
el.find("h2.title").html(title) if title
|
|
el.find("p.message").html(message) if message
|
|
|
|
return {
|
|
start: => @lightboxService.open(el)
|
|
stop: => @lightboxService.close(el)
|
|
update: (status, title, message, percent) =>
|
|
el.find("h2.title").html(title) if title
|
|
el.find("p.message").html(message) if message
|
|
|
|
if percent
|
|
el.find(".spin").addClass("hidden")
|
|
el.find(".progress-bar-wrapper").removeClass("hidden")
|
|
el.find(".progress-bar-wrapper > .bar").width(percent + '%')
|
|
el.find(".progress-bar-wrapper > span").html(percent + '%').css('left', (percent - 9) + '%' )
|
|
else
|
|
el.find(".spin").removeClass("hidden")
|
|
el.find(".progress-bar-wrapper").addClass("hidden")
|
|
}
|
|
|
|
notify: (type, message, title, time) ->
|
|
# NOTE: Typesi are: error, success, light-error
|
|
# See partials/components/notification-message.jade)
|
|
# Add default texts to NOTIFICATION_MSG for new notification types
|
|
|
|
selector = ".notification-message-#{type}"
|
|
el = angular.element(selector)
|
|
|
|
return if el.hasClass("active")
|
|
|
|
if title
|
|
el.find("h4").html(title)
|
|
else
|
|
el.find("h4").html(NOTIFICATION_MSG[type].title)
|
|
|
|
if message
|
|
el.find("p").html(message)
|
|
else
|
|
el.find("p").html(NOTIFICATION_MSG[type].message)
|
|
|
|
body = angular.element("body")
|
|
body.find(".notification-message .notification-light")
|
|
.removeClass('active')
|
|
.addClass('inactive')
|
|
|
|
body.find(selector)
|
|
.removeClass('inactive')
|
|
.addClass('active')
|
|
|
|
if @.tsem
|
|
cancelTimeout(@.tsem)
|
|
|
|
if !time
|
|
time = if type == 'error' or type == 'light-error' then 3500 else 1500
|
|
|
|
@.tsem = timeout time, =>
|
|
body.find(selector)
|
|
.removeClass('active')
|
|
.addClass('inactive')
|
|
|
|
delete @.tsem
|
|
|
|
el.on "click", ".icon-delete", (event) =>
|
|
body.find(selector)
|
|
.removeClass('active')
|
|
.addClass('inactive')
|
|
|
|
|
|
module = angular.module("taigaCommon")
|
|
module.service("$tgConfirm", ConfirmService)
|