Files
habitica/website/client-old/js/components/groupMembersAutocomplete/groupMembersAutocompleteDirective.js
Matteo Pagliazzi 98c019a0b6 Upgrade lodash to v4 and lint more files (#8495)
* 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
2017-03-01 17:10:48 +01:00

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);
});
}
}
});
};
},
};
}
}());