mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-19 15:48:04 +01:00
*adds the following new dependencies: moment, express-csv *recommend replacing functionality of 'relative-date' with features from 'moment' *supports retrieval of CSV history via the API and in browser **/api/v1/export/history (requires typical API authorization) **/export/history.csv (requires session authorization) *adds new routes for data export
188 lines
7.0 KiB
JavaScript
188 lines
7.0 KiB
JavaScript
"use strict";
|
|
|
|
window.habitrpg = angular.module('habitrpg',
|
|
['ngResource', 'ngSanitize', 'userServices', 'groupServices', 'memberServices', 'challengeServices',
|
|
'sharedServices', 'authServices', 'notificationServices', 'guideServices',
|
|
'ui.bootstrap', 'ui.keypress', 'ui.router', 'chieffancypants.loadingBar', 'At'])
|
|
|
|
// @see https://github.com/angular-ui/ui-router/issues/110 and https://github.com/HabitRPG/habitrpg/issues/1705
|
|
// temporary hack until they have a better solution
|
|
.value('$anchorScroll', angular.noop)
|
|
|
|
.constant("API_URL", "")
|
|
.constant("STORAGE_USER_ID", 'habitrpg-user')
|
|
.constant("STORAGE_SETTINGS_ID", 'habit-mobile-settings')
|
|
//.constant("STORAGE_GROUPS_ID", "") // if we decide to take groups offline
|
|
|
|
.config(['$stateProvider', '$urlRouterProvider', '$httpProvider', 'STORAGE_SETTINGS_ID',
|
|
function($stateProvider, $urlRouterProvider, $httpProvider, STORAGE_SETTINGS_ID) {
|
|
|
|
$urlRouterProvider
|
|
// Setup default selected tabs
|
|
.when('/options', '/options/profile/avatar')
|
|
.when('/options/profile', '/options/profile/avatar')
|
|
.when('/options/groups', '/options/groups/tavern')
|
|
.when('/options/groups/guilds', '/options/groups/guilds/public')
|
|
.when('/options/inventory', '/options/inventory/inventory')
|
|
|
|
// redirect states that don't match
|
|
.otherwise("/tasks");
|
|
|
|
$stateProvider
|
|
|
|
// Tasks
|
|
.state('tasks', {
|
|
url: "/tasks",
|
|
templateUrl: "partials/main.html"
|
|
})
|
|
|
|
// Options
|
|
.state('options', {
|
|
url: "/options",
|
|
templateUrl: "partials/options.html",
|
|
controller: function(){}
|
|
})
|
|
|
|
// Options > Profile
|
|
.state('options.profile', {
|
|
url: "/profile",
|
|
templateUrl: "partials/options.profile.html",
|
|
controller: 'UserCtrl'
|
|
})
|
|
.state('options.profile.avatar', {
|
|
url: "/avatar",
|
|
templateUrl: "partials/options.profile.avatar.html"
|
|
})
|
|
.state('options.profile.stats', {
|
|
url: "/stats",
|
|
templateUrl: "partials/options.profile.stats.html"
|
|
})
|
|
.state('options.profile.profile', {
|
|
url: "/profile",
|
|
templateUrl: "partials/options.profile.profile.html"
|
|
})
|
|
.state('options.profile.data', {
|
|
url: "/profile/data",
|
|
templateUrl: "partials/options.profile.data.html"
|
|
})
|
|
|
|
// Options > Groups
|
|
.state('options.social', {
|
|
url: "/groups",
|
|
templateUrl: "partials/options.social.html"
|
|
})
|
|
.state('options.social.tavern', {
|
|
url: "/tavern",
|
|
templateUrl: "partials/options.social.tavern.html",
|
|
controller: 'TavernCtrl'
|
|
})
|
|
.state('options.social.party', {
|
|
url: '/party',
|
|
templateUrl: "partials/options.social.party.html",
|
|
controller: 'PartyCtrl'
|
|
})
|
|
.state('options.social.guilds', {
|
|
url: '/guilds',
|
|
templateUrl: "partials/options.social.guilds.html",
|
|
controller: 'GuildsCtrl'
|
|
})
|
|
.state('options.social.guilds.public', {
|
|
url: '/public',
|
|
templateUrl: "partials/options.social.guilds.public.html"
|
|
})
|
|
.state('options.social.guilds.create', {
|
|
url: '/create',
|
|
templateUrl: "partials/options.social.guilds.create.html"
|
|
})
|
|
.state('options.social.guilds.detail', {
|
|
url: '/:gid',
|
|
templateUrl: 'partials/options.social.guilds.detail.html',
|
|
controller: ['$scope', 'Groups', '$stateParams', function($scope, Groups, $stateParams){
|
|
$scope.group = Groups.Group.get({gid:$stateParams.gid});
|
|
}]
|
|
})
|
|
|
|
// Options > Social > Challenges
|
|
.state('options.social.challenges', {
|
|
url: "/challenges",
|
|
controller: 'ChallengesCtrl',
|
|
templateUrl: "partials/options.social.challenges.html"
|
|
})
|
|
.state('options.social.challenges.detail', {
|
|
url: '/:cid',
|
|
templateUrl: 'partials/options.social.challenges.detail.html',
|
|
controller: ['$scope', 'Challenges', '$stateParams',
|
|
function($scope, Challenges, $stateParams){
|
|
$scope.obj = $scope.challenge = Challenges.Challenge.get({cid:$stateParams.cid}, function(){
|
|
$scope.challenge._locked = true;
|
|
});
|
|
}]
|
|
})
|
|
.state('options.social.challenges.detail.member', {
|
|
url: '/:uid',
|
|
templateUrl: 'partials/options.social.challenges.detail.member.html',
|
|
controller: ['$scope', 'Challenges', '$stateParams',
|
|
function($scope, Challenges, $stateParams){
|
|
$scope.obj = Challenges.Challenge.getMember({cid:$stateParams.cid, uid:$stateParams.uid}, function(){
|
|
$scope.obj._locked = true;
|
|
});
|
|
}]
|
|
})
|
|
|
|
// Options > Inventory
|
|
.state('options.inventory', {
|
|
url: '/inventory',
|
|
templateUrl: "partials/options.inventory.html"
|
|
})
|
|
.state('options.inventory.inventory', {
|
|
url: '/inventory',
|
|
templateUrl: "partials/options.inventory.inventory.html"
|
|
})
|
|
.state('options.inventory.stable', {
|
|
url: '/stable',
|
|
templateUrl: "partials/options.inventory.stable.html"
|
|
})
|
|
|
|
// Options > Settings
|
|
.state('options.settings', {
|
|
url: "/settings",
|
|
controller: 'SettingsCtrl',
|
|
templateUrl: "partials/options.settings.html"
|
|
})
|
|
|
|
// Options > Settings
|
|
.state('options.admin', {
|
|
url: "/admin",
|
|
controller: 'AdminCtrl',
|
|
templateUrl: "partials/options.admin.html"
|
|
})
|
|
|
|
var settings = JSON.parse(localStorage.getItem(STORAGE_SETTINGS_ID));
|
|
if (settings && settings.auth) {
|
|
$httpProvider.defaults.headers.common['Content-Type'] = 'application/json;charset=utf-8';
|
|
$httpProvider.defaults.headers.common['x-api-user'] = settings.auth.apiId;
|
|
$httpProvider.defaults.headers.common['x-api-key'] = settings.auth.apiToken;
|
|
}
|
|
|
|
// Handle errors
|
|
var interceptor = ['$rootScope', '$q', function ($rootScope, $q) {
|
|
function success(response) {
|
|
return response;
|
|
}
|
|
function error(response) {
|
|
//var status = response.status;
|
|
response.data = (response.data.err) ? response.data.err : response.data;
|
|
if (response.status == 0) response.data = 'Server currently unreachable.';
|
|
if (response.status == 500) response.data += ' (see Chrome console for more details).';
|
|
|
|
var error = response.status == 0 ? response.data : ('Error ' + response.status + ': ' + response.data);
|
|
$rootScope.$broadcast('responseError', error);
|
|
console.log(arguments);
|
|
return $q.reject(response);
|
|
}
|
|
return function (promise) {
|
|
return promise.then(success, error);
|
|
}
|
|
}];
|
|
$httpProvider.responseInterceptors.push(interceptor);
|
|
}]) |