mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-18 15:17:25 +01:00
* common: import lodash modules separately * remove test/content from .eslintignore, fix with eslint --fix content/index * lint test/content * lint content/index except for lodash methods * upgrade server/models * upgrade server/middlewares and server/libs * port server/controllers/top-level * port server/controllers/api-v3 * port views and tests * client old port lodash and _(, missing _. * upgrade client-old * port common/script (root level files only) * port common/script/fns * port common/libs * port common/script/ops * port common/script/content and common/script/libs/shops.js * misc fixes * misc fixes * misc fixes * more tests fixes * fix payments test stubbing, down to 2 failing tests * remove more instances of lodash wrapping * fix bug where toObject does not clone object * fix tests * upgrade migration or add lodash 4 note * update shrinkwrap * fix linting * upgrade eslint-config-habitrpg * update shrinkwrap * recompile shrinkwrap
80 lines
2.9 KiB
JavaScript
80 lines
2.9 KiB
JavaScript
'use strict';
|
|
|
|
(function(){
|
|
angular
|
|
.module('habitrpg')
|
|
.directive('groupMembersAutocomplete', groupMembersAutocomplete);
|
|
|
|
groupMembersAutocomplete.$inject = [
|
|
'$parse',
|
|
'$rootScope',
|
|
];
|
|
|
|
function groupMembersAutocomplete($parse, $rootScope) {
|
|
|
|
return {
|
|
templateUrl: 'partials/groups.members.autocomplete.html',
|
|
compile: function (element, attrs) {
|
|
var modelAccessor = $parse(attrs.ngModel);
|
|
|
|
return function (scope, element, attrs, controller) {
|
|
var availableTags = _.map(scope.group.members, 'profile.name');
|
|
var memberProfileNameToIdMap = _.fromPairs(_.map(scope.group.members, function(item) {
|
|
return [item.profile.name, item.id]
|
|
}));
|
|
var memberIdToProfileNameMap = _.fromPairs(_.map(scope.group.members, function(item) {
|
|
return [item.id, item.profile.name]
|
|
}));
|
|
|
|
var currentTags = [];
|
|
_.each(scope.task.group.assignedUsers, function(userId) { currentTags.push(memberIdToProfileNameMap[userId]) });
|
|
|
|
var allowedTags = [];
|
|
_.each(scope.task.group.members, function(userId) { currentTags.push(memberIdToProfileNameMap[userId]) });
|
|
|
|
var taggle = new Taggle('taggle', {
|
|
tags: currentTags,
|
|
allowedTags: allowedTags,
|
|
allowDuplicates: false,
|
|
preserveCase: true,
|
|
delimeter: '|',
|
|
placeholder: window.env.t('assignFieldPlaceholder'),
|
|
onBeforeTagAdd: function(event, tag) {
|
|
return confirm(window.env.t('confirmAddTag', {tag: tag}));
|
|
},
|
|
onTagAdd: function(event, tag) {
|
|
$rootScope.$broadcast('addedGroupMember', memberProfileNameToIdMap[tag]);
|
|
},
|
|
onBeforeTagRemove: function(event, tag) {
|
|
return confirm(window.env.t('confirmRemoveTag', {tag: tag}))
|
|
},
|
|
onTagRemove: function(event, tag) {
|
|
$rootScope.$broadcast('removedGroupMember', memberProfileNameToIdMap[tag]);
|
|
}
|
|
});
|
|
var container = taggle.getContainer();
|
|
var input = taggle.getInput();
|
|
|
|
$(input).autocomplete({
|
|
source: availableTags, // See jQuery UI documentaton for options
|
|
appendTo: container,
|
|
position: { at: "left bottom", of: container },
|
|
select: function(event, data) {
|
|
event.preventDefault();
|
|
//Add the tag if user clicks
|
|
if (event.which === 1) {
|
|
taggle.add(data.item.value);
|
|
var taggleTags = taggle.getTags();
|
|
scope.$apply(function (scope) {
|
|
// Change bound variable
|
|
modelAccessor.assign(scope, taggleTags.values);
|
|
});
|
|
}
|
|
}
|
|
});
|
|
};
|
|
},
|
|
};
|
|
}
|
|
}());
|