taiga-front/app/modules/external-apps/external-app.controller.coffee

59 lines
1.9 KiB
CoffeeScript

taiga = @.taiga
class ExternalAppController extends taiga.Controller
@.$inject = [
"$routeParams",
"tgExternalAppsService",
"$window",
"tgCurrentUserService",
"$location",
"$tgNavUrls",
"tgXhrErrorService",
"tgLoader"
]
constructor: (@routeParams, @externalAppsService, @window, @currentUserService,
@location, @navUrls, @xhrError, @loader) ->
@loader.start(false)
@._applicationId = @routeParams.application
@._state = @routeParams.state
@._getApplicationToken()
@._user = @currentUserService.getUser()
@._application = null
nextUrl = encodeURIComponent(@location.url())
loginUrl = @navUrls.resolve("login")
@.loginWithAnotherUserUrl = "#{loginUrl}?next=#{nextUrl}"
taiga.defineImmutableProperty @, "user", () => @._user
taiga.defineImmutableProperty @, "application", () => @._application
_redirect: (applicationToken) =>
nextUrl = applicationToken.get("next_url")
@window.open(nextUrl, "_self")
_getApplicationToken: =>
return @externalAppsService.getApplicationToken(@._applicationId, @._state)
.then (data) =>
@._application = data.get("application")
if data.get("auth_code")
@._redirect(data)
else
@loader.pageLoaded()
.catch (xhr) =>
return @xhrError.response(xhr)
cancel: () ->
@window.history.back()
createApplicationToken: =>
return @externalAppsService.authorizeApplicationToken(@._applicationId, @._state)
.then (data) =>
@._redirect(data)
.catch (xhr) =>
return @xhrError.response(xhr)
angular.module("taigaExternalApps").controller("ExternalApp", ExternalAppController)