zulip/static/js/settings_user_groups.js

266 lines
9.2 KiB
JavaScript

var settings_user_groups = (function () {
var exports = {};
var meta = {
loaded: false,
};
exports.reset = function () {
meta.loaded = false;
};
exports.reload = function () {
var user_groups_section = $('#user-groups').expectOne();
user_groups_section.html('');
exports.populate_user_groups();
};
exports.populate_user_groups = function () {
if (!meta.loaded) {
return;
}
var user_groups_section = $('#user-groups').expectOne();
var user_groups_array = user_groups.get_realm_user_groups();
_.each(user_groups_array, function (data) {
user_groups_section.append(templates.render('admin_user_group_list', {
user_group: {
name: data.name,
id: data.id,
description: data.description,
},
}));
var pill_container = $('.pill-container[data-group-pills="' + data.name + '"]');
var pills = input_pill(pill_container);
data.members.forEach(function (user_id) {
var user = people.get_person_from_user_id(user_id);
if (user) {
pills.pill.append(user.full_name, user_id);
} else {
blueslip.warn('Unknown user ID ' + user_id + ' in members of user group ' + data.name);
}
});
function update_save_state(draft_group) {
var original_group = user_groups.get_user_group_from_id(data.id).members;
var same_groups = _.isEqual(_.sortBy(draft_group), _.sortBy(original_group));
var save_changes = pill_container.siblings('.save-member-changes');
var save_hidden = save_changes.css('display') === 'none';
if ((!draft_group.length || same_groups) && !save_hidden) {
save_changes.fadeOut();
} else if (!same_groups && draft_group.length && save_hidden) {
save_changes.css({display: 'inline-block', opacity: '0'}).fadeTo(400, 1);
}
}
var input = pill_container.children('.input');
input.typeahead({
items: 5,
fixed: true,
dropup: true,
source: people.get_realm_persons,
highlighter: function (item) {
return typeahead_helper.render_person(item);
},
matcher: function (item) {
if (pills.keys().includes(item.user_id)) {
return false;
}
var query = this.query.toLowerCase();
return (item.email.toLowerCase().indexOf(query) !== -1
|| item.full_name.toLowerCase().indexOf(query) !== -1);
},
sorter: function (matches) {
return typeahead_helper.sort_recipientbox_typeahead(
this.query, matches, "");
},
updater: function (user) {
pills.pill.append(user.full_name, user.user_id);
input.text('');
update_save_state(pills.keys());
},
stopAdvance: true,
});
pills.onPillCreate(function (value, reject) {
var person = people.get_by_email(value);
var draft_group = pills.keys();
if (!person || draft_group.includes(person.user_id)) {
return reject();
}
draft_group.push(person.user_id);
update_save_state(draft_group);
return { key: person.user_id, value: person.full_name };
});
pills.onPillRemove(function () {
update_save_state(pills.keys());
});
$('#user-groups #' + data.id).on('click', '.save-member-changes', function () {
var draft_group = pills.keys();
var group_data = user_groups.get_user_group_from_id(data.id);
var original_group = group_data.members;
var added = _.difference(draft_group, original_group);
var removed = _.difference(original_group, draft_group);
var btn = $(this);
channel.post({
url: "/json/user_groups/" + data.id + '/members',
data: {
add: JSON.stringify(added),
delete: JSON.stringify(removed),
},
success: function () {
original_group = _.reject(original_group, function (e) {
return removed.includes(e);
});
original_group = original_group.concat(added);
group_data.members = original_group;
user_groups.remove(group_data);
user_groups.add(group_data);
btn.text(i18n.t("Saved!")).delay(200).fadeOut(function () {
$(this).html('<i class="fa fa-check" aria-hidden="true"></i>');
});
},
error: function () {
btn.text(i18n.t("Failed!"));
},
});
});
});
};
exports.set_up = function () {
meta.loaded = true;
exports.populate_user_groups();
$(".organization").on("submit", "form.admin-user-group-form", function (e) {
e.preventDefault();
e.stopPropagation();
var user_group_status = $('#admin-user-group-status');
var group = {
members: JSON.stringify([people.my_current_user_id()]),
};
_.each($(this).serializeArray(), function (obj) {
if (obj.value.trim() === "") {
return;
}
group[obj.name] = obj.value;
});
channel.post({
url: "/json/user_groups/create",
data: group,
success: function () {
user_group_status.hide();
ui_report.success(i18n.t("User group added!"), user_group_status);
$("form.admin-user-group-form input[type='text']").val("");
},
error: function (xhr) {
user_group_status.hide();
var errors = JSON.parse(xhr.responseText).msg;
xhr.responseText = JSON.stringify({msg: errors});
ui_report.error(i18n.t("Failed"), xhr, user_group_status);
},
});
});
$('#user-groups').on('click', '.delete', function () {
var group_id = $(this).parents('.user-group').attr('id');
var user_group = user_groups.get_user_group_from_id(group_id);
var btn = $(this);
channel.del({
url: "/json/user_groups/" + group_id,
data: {
id: group_id,
},
success: function () {
user_groups.remove(user_group);
settings_user_groups.reload();
},
error: function () {
btn.text(i18n.t("Failed!"));
},
});
});
$('#user-groups').on('keypress', '.user-group h4 > span', function (e) {
if (e.which === 13) {
e.preventDefault();
}
});
$('#user-groups').on('input', '.user-group h4 > span', function () {
var element = this.className;
var current_text = $(this).text();
var sibling_element = $(this).siblings('span').first().attr('class');
var sibling_text = $(this).siblings('span').first().text();
var group_id = $(this).parents('.user-group').attr('id');
var user_group = user_groups.get_user_group_from_id(group_id);
var saved_text = user_group[element];
var saved_sibling_text = user_group[sibling_element];
var has_changes = saved_text !== current_text || saved_sibling_text !== sibling_text;
var save_changes = $(this).siblings('.save-group-changes');
var save_hidden = save_changes.css('display') === 'none';
var has_content = current_text.trim() !== '' && sibling_text.trim() !== '';
if (has_changes && save_hidden && has_content) {
save_changes.css({display: 'inline', opacity: '0'}).fadeTo(400, 1);
} else if ((!has_changes || !has_content) && !save_hidden) {
save_changes.fadeOut();
}
});
$('#user-groups').on('click', '.save-group-changes', function () {
var group_id = $(this).parents('.user-group').attr('id');
var group_data = user_groups.get_user_group_from_id(group_id);
var description = $(this).siblings('.description').text().trim();
var name = $(this).siblings('.name').text().trim();
var btn = $(this);
channel.patch({
url: "/json/user_groups/" + group_id,
data: {
name: name,
description: description,
},
success: function () {
user_groups.remove(group_data);
group_data.description = description;
group_data.name = name;
user_groups.add(group_data);
btn.text(i18n.t("Saved!")).delay(200).fadeOut(function () {
$(this).html('<i class="fa fa-check" aria-hidden="true"></i>');
});
},
error: function () {
btn.text(i18n.t("Failed!"));
},
});
});
};
return exports;
}());
if (typeof module !== 'undefined') {
module.exports = settings_user_groups;
}