mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-18 07:07:35 +01:00
* Added all ui components back * Added group ui items back and initial group approval directive * Added approval list view with approving functionality * Added notification display for group approvals * Fixed linting issues * Removed expectation from beforeEach * Moved string to locale * Added per use group plan for stripe * Added tests for stripe group plan upgrade * Removed paypal option * Abstract sub blocks. Hit group sub block from user settings page. Added group subscriptin beneifts display * Fixed lint issue * Added pricing and adjusted styles * Moved text to translations * Added group email types * Fixed typo * Fixed group plan abstraction and other style issues * Fixed email unit test * Added type to group plan to filter our group plans * Removed dev protection from routes * Removed hard coding and fixed upgrade plan * Added error when group has subscription and tries to remove * Fixed payment unit tests * Added custom string and moved subscription check up in the logic * Added ability for old leader to delete subscription the created * Allowed old guild leader to edit their group subscription * Fixed linting and tests * Added group sub page to user sub settings * Added approval and group tasks requests back. Hid user group sub on profile * Added group tasks sync after adding to allow for editing * Fixed promise chain when resolving group * Added approvals to group promise chain * Ensured compelted group todos are not delted at cron * Updated copy and other minor styles * Added group field to tags and recolored group tag. * Added chat message when task is claimed * Preventing task scoring when approval is needed * Added approval requested indicator * Updated column with for tasks on group page * Added checklist sync on assign * Added sync for checklist items * Added checkilist sync when task is updated * Added checklist sync remove * Sanatized group tasks when updated * Fixed lint issues * Added instant scoring of approved task * Added task modal * Fixed editing of challenge and group tasks * Added cancel button * Added add new checklist option to update sync * Added remove for checklist * Added checklist update * Added difference check and sync for checklist if there is a diff * Fixed task syncing * Fixed linting issues * Fixed styles and karma tests * Fixed minor style issues * Fixed obj transfer on scope * Fixed broken tests * Added new benefits page * Updated group page styles * Updated benefits page style * Added translations * Prevented sync with empty trask list * Added task title to edit modal * Added new group plans page and upgrade redirect * Added group plans redirect to upgrade * Fixed party home page being hidden and home button click * Fixed dynamic changing of task status and grey popup * Fixed tag editing * Hid benifites information if group has subscription * Added quotes to task name * Fixed issue with assigning multiple users * Added new group plans ctrl * Hid menu from public guilds * Fixed task sync issue * Updated placeholder for assign field * Added correct cost to subscribe details * Hid create, edit, delete task options from non group leaders * Prevented some front end modifications to group tasks * Hid tags option from group original task * Added refresh for approvals and group tasks * Prepend new group tasks * Fix last checklist item sync * Fixed casing issue with tags * Added claimed by message on hover * Prevent user from deleting assigned task * Added single route for group plan sign up and payments * Abstracted stripe payments and added initial tests * Abstracted amazon and added initial tests * Fixed create group message * Update group id check and return group * Updated to use the new returned group * Fixed linting and promise issues * Fixed broken leave test after merge issue * Fixed undefined approval error and editing/deleting challenge tasks * Add pricing to group plans, removed confirmation, and fixed redirect after payment * Updated group plan cost text
145 lines
4.6 KiB
JavaScript
145 lines
4.6 KiB
JavaScript
"use strict";
|
|
|
|
habitrpg.controller("GroupsCtrl", ['$scope', '$rootScope', 'Shared', 'Groups', '$http', '$q', 'User', 'Members', '$state', 'Notification',
|
|
function($scope, $rootScope, Shared, Groups, $http, $q, User, Members, $state, Notification) {
|
|
$scope.isMemberOfPendingQuest = function (userid, group) {
|
|
if (!group.quest || !group.quest.members) return false;
|
|
if (group.quest.active) return false; // quest is started, not pending
|
|
return userid in group.quest.members && group.quest.members[userid] != false;
|
|
};
|
|
|
|
$scope.isMemberOfRunningQuest = function (userid, group) {
|
|
if (!group.quest || !group.quest.members) return false;
|
|
if (!group.quest.active) return false; // quest is pending, not started
|
|
return group.quest.members[userid];
|
|
};
|
|
|
|
$scope.isMemberOfGroup = function (userid, group) {
|
|
// If the group is a guild, just check for an intersection with the
|
|
// current user's guilds, rather than checking the members of the group.
|
|
if(group.type === 'guild') {
|
|
return _.detect(User.user.guilds, function(guildId) { return guildId === group._id });
|
|
}
|
|
|
|
// Similarly, if we're dealing with the user's current party, return true.
|
|
if(group.type === 'party') {
|
|
var currentParty = group;
|
|
if(currentParty._id && currentParty._id === group._id) return true;
|
|
}
|
|
|
|
if (!group.members) return false;
|
|
var memberIds = _.map(group.members, function(x){return x._id});
|
|
return ~(memberIds.indexOf(userid));
|
|
};
|
|
|
|
$scope.isMember = function (user, group) {
|
|
return ~(group.members.indexOf(user._id));
|
|
};
|
|
|
|
$scope.Members = Members;
|
|
|
|
$scope._editing = {group: false};
|
|
$scope.groupCopy = {};
|
|
|
|
$scope.editGroup = function (group) {
|
|
angular.copy(group, $scope.groupCopy);
|
|
group._editing = true;
|
|
};
|
|
|
|
$scope.saveEdit = function (group) {
|
|
var newLeader = $scope.groupCopy._newLeader && $scope.groupCopy._newLeader._id;
|
|
|
|
if (newLeader) {
|
|
$scope.groupCopy.leader = newLeader;
|
|
}
|
|
|
|
angular.copy($scope.groupCopy, group);
|
|
|
|
Groups.Group.update(group);
|
|
|
|
$scope.cancelEdit(group);
|
|
};
|
|
|
|
$scope.cancelEdit = function (group) {
|
|
group._editing = false;
|
|
$scope.groupCopy = {};
|
|
};
|
|
|
|
$scope.deleteAllMessages = function() {
|
|
if (confirm(window.env.t('confirmDeleteAllMessages'))) {
|
|
User.clearPMs();
|
|
}
|
|
};
|
|
|
|
// ------ Modals ------
|
|
|
|
$scope.clickMember = function (uid, forceShow) {
|
|
if (User.user._id == uid && !forceShow) {
|
|
if ($state.is('tasks')) {
|
|
$state.go('options.profile.avatar');
|
|
} else {
|
|
$state.go('tasks');
|
|
}
|
|
} else {
|
|
// We need the member information up top here, but then we pass it down to the modal controller
|
|
// down below. Better way of handling this?
|
|
Members.selectMember(uid)
|
|
.then(function () {
|
|
$rootScope.openModal('member', {controller: 'MemberModalCtrl', windowClass: 'profile-modal', size: 'lg'});
|
|
});
|
|
}
|
|
};
|
|
|
|
$scope.removeMember = function (group, member, isMember) {
|
|
// TODO find a better way to do this (share data with remove member modal)
|
|
$scope.removeMemberData = {
|
|
group: group,
|
|
member: member,
|
|
isMember: isMember
|
|
};
|
|
$rootScope.openModal('remove-member', {scope: $scope});
|
|
};
|
|
|
|
$scope.confirmRemoveMember = function (confirm) {
|
|
if (confirm) {
|
|
Groups.Group.removeMember(
|
|
$scope.removeMemberData.group._id,
|
|
$scope.removeMemberData.member._id,
|
|
$scope.removeMemberData.message
|
|
).then(function (response) {
|
|
if($scope.removeMemberData.isMember){
|
|
_.pull($scope.removeMemberData.group.members, $scope.removeMemberData.member);
|
|
}else{
|
|
_.pull($scope.removeMemberData.group.invites, $scope.removeMemberData.member);
|
|
}
|
|
|
|
$scope.removeMemberData = undefined;
|
|
});
|
|
} else {
|
|
$scope.removeMemberData = undefined;
|
|
}
|
|
};
|
|
|
|
$scope.openInviteModal = function (group) {
|
|
if (group.type !== 'party' && group.type !== 'guild') {
|
|
return console.log('Invalid group type.')
|
|
}
|
|
|
|
$rootScope.openModal('invite-' + group.type, {
|
|
controller:'InviteToGroupCtrl',
|
|
resolve: {
|
|
injectedGroup: function(){
|
|
return group;
|
|
}
|
|
}
|
|
});
|
|
};
|
|
|
|
$scope.quickReply = function (uid) {
|
|
Members.selectMember(uid)
|
|
.then(function (response) {
|
|
$rootScope.openModal('private-message', {controller: 'MemberModalCtrl'});
|
|
});
|
|
}
|
|
}]);
|