Files
NodeBB/public/src/admin/manage/category.js

447 lines
13 KiB
JavaScript
Raw Normal View History

2017-02-18 01:56:23 -07:00
'use strict';
2014-12-30 13:04:31 -05:00
define('admin/manage/category', [
'uploader',
'iconSelect',
'admin/modules/colorpicker',
'autocomplete',
2017-02-17 19:31:21 -07:00
'translator',
], function (uploader, iconSelect, colorpicker, autocomplete, translator) {
2014-12-30 13:04:31 -05:00
var Category = {};
2016-12-09 18:53:08 +03:00
var modified_categories = {};
2014-12-30 13:04:31 -05:00
Category.init = function () {
2017-05-29 14:47:01 -04:00
$('#category-settings select').each(function () {
2014-12-30 13:04:31 -05:00
var $this = $(this);
$this.val($this.attr('data-value'));
});
2017-05-29 14:47:01 -04:00
$('#category-selector').on('change', function () {
ajaxify.go('admin/manage/categories/' + $(this).val());
});
2014-12-30 13:04:31 -05:00
function enableColorPicker(idx, inputEl) {
2017-02-17 20:20:42 -07:00
var $inputEl = $(inputEl);
var previewEl = $inputEl.parents('[data-cid]').find('.category-preview');
2014-12-30 13:04:31 -05:00
colorpicker.enable($inputEl, function (hsb, hex) {
2014-12-30 13:04:31 -05:00
if ($inputEl.attr('data-name') === 'bgColor') {
previewEl.css('background-color', '#' + hex);
2014-12-30 13:04:31 -05:00
} else if ($inputEl.attr('data-name') === 'color') {
previewEl.css('color', '#' + hex);
}
modified($inputEl[0]);
});
}
2015-09-20 15:38:54 -04:00
2017-05-29 14:47:01 -04:00
$('#category-settings input, #category-settings select').not($('.privilege-table-container input'))
.on('change', function (ev) {
2015-09-01 11:57:40 -04:00
modified(ev.target);
})
.on('keydown', function (ev) {
2015-09-01 11:57:40 -04:00
if (ev.which === 13) {
ev.preventDefault();
return false;
}
});
2014-12-30 13:04:31 -05:00
$('[data-name="imageClass"]').on('change', function () {
$('.category-preview').css('background-size', $(this).val());
});
2015-01-01 15:35:22 -05:00
$('[data-name="bgColor"], [data-name="color"]').each(enableColorPicker);
2014-12-30 13:04:31 -05:00
2016-12-09 18:53:08 +03:00
$('#save').on('click', function () {
if (Object.keys(modified_categories).length) {
socket.emit('admin.categories.update', modified_categories, function (err, result) {
if (err) {
return app.alertError(err.message);
}
if (result && result.length) {
app.flags._unsaved = false;
app.alert({
title: 'Updated Categories',
message: 'Category IDs ' + result.join(', ') + ' was successfully updated.',
type: 'success',
2017-02-17 19:31:21 -07:00
timeout: 2000,
2016-12-09 18:53:08 +03:00
});
}
});
modified_categories = {};
}
return false;
});
$('.purge').on('click', function (e) {
e.preventDefault();
2014-12-30 13:04:31 -05:00
bootbox.confirm(translator.compile(
'admin/manage/categories:alert.confirm-purge',
2017-02-17 20:20:42 -07:00
$('form.category').find('input[data-name="name"]').val()
), function (confirm) {
2015-01-01 15:35:22 -05:00
if (!confirm) {
return;
}
socket.emit('admin.categories.purge', ajaxify.data.category.cid, function (err) {
2015-01-01 15:35:22 -05:00
if (err) {
return app.alertError(err.message);
2014-12-30 13:04:31 -05:00
}
app.alertSuccess('[[admin/manage/categories:alert.purge-success]]');
ajaxify.go('admin/manage/categories');
2014-12-30 13:04:31 -05:00
});
});
2015-01-01 15:35:22 -05:00
});
$('.copy-settings').on('click', function () {
selectCategoryModal(function (cid) {
2017-02-18 12:30:49 -07:00
socket.emit('admin.categories.copySettingsFrom', { fromCid: cid, toCid: ajaxify.data.category.cid }, function (err) {
2016-05-23 12:59:33 +03:00
if (err) {
return app.alertError(err.message);
2016-04-01 15:02:17 +03:00
}
app.alertSuccess('[[admin/manage/categories:alert.copy-success]]');
2016-05-23 12:59:33 +03:00
ajaxify.refresh();
2016-04-01 15:02:17 +03:00
});
});
2016-05-23 12:59:33 +03:00
return false;
2016-04-01 15:02:17 +03:00
});
$('.upload-button').on('click', function () {
2016-03-24 16:15:22 +02:00
var inputEl = $(this);
var cid = inputEl.attr('data-cid');
2015-01-01 15:35:22 -05:00
2016-02-29 14:23:12 +02:00
uploader.show({
title: '[[admin/manage/categories:alert.upload-image]]',
2016-02-29 14:23:12 +02:00
route: config.relative_path + '/api/admin/category/uploadpicture',
2017-02-18 12:30:49 -07:00
params: { cid: cid },
}, function (imageUrlOnServer) {
2016-03-24 16:15:22 +02:00
$('#category-image').val(imageUrlOnServer);
var previewBox = inputEl.parent().parent().siblings('.category-preview');
previewBox.css('background', 'url(' + imageUrlOnServer + '?' + new Date().getTime() + ')');
2016-03-24 16:15:22 +02:00
modified($('#category-image'));
2015-01-01 15:35:22 -05:00
});
});
$('#category-image').on('change', function () {
2016-03-24 16:15:22 +02:00
$('.category-preview').css('background-image', $(this).val() ? ('url("' + $(this).val() + '")') : '');
});
$('.delete-image').on('click', function (e) {
2015-03-27 15:43:37 +03:00
e.preventDefault();
2016-03-24 16:15:22 +02:00
var inputEl = $('#category-image');
var previewBox = $('.category-preview');
2015-03-27 15:43:37 +03:00
inputEl.val('');
previewBox.css('background-image', '');
modified(inputEl[0]);
2015-03-27 15:58:13 +03:00
$(this).parent().addClass('hide').hide();
2015-03-27 15:43:37 +03:00
});
$('.category-preview').on('click', function () {
2015-01-01 16:24:47 -05:00
iconSelect.init($(this).find('i'), modified);
});
2015-07-07 17:23:41 -04:00
$('button[data-action="setParent"], button[data-action="changeParent"]').on('click', Category.launchParentSelector);
$('button[data-action="removeParent"]').on('click', function () {
2016-10-13 11:42:29 +02:00
var payload = {};
2015-07-06 14:33:43 -04:00
payload[ajaxify.data.category.cid] = {
2017-02-17 19:31:21 -07:00
parentCid: 0,
};
socket.emit('admin.categories.update', payload, function (err) {
if (err) {
return app.alertError(err.message);
}
2015-07-07 17:23:41 -04:00
$('button[data-action="removeParent"]').parent().addClass('hide');
2015-09-20 15:38:54 -04:00
$('button[data-action="changeParent"]').parent().addClass('hide');
2015-07-07 17:23:41 -04:00
$('button[data-action="setParent"]').removeClass('hide');
});
});
Category.setupPrivilegeTable();
2016-12-09 18:53:08 +03:00
handleTags();
2014-12-30 13:04:31 -05:00
};
2016-12-09 18:53:08 +03:00
function modified(el) {
var cid = ajaxify.data.category.cid;
if (cid) {
modified_categories[cid] = modified_categories[cid] || {};
modified_categories[cid][$(el).attr('data-name')] = $(el).val();
app.flags = app.flags || {};
app.flags._unsaved = true;
}
}
function handleTags() {
var tagEl = $('#tag-whitelist');
tagEl.tagsinput({
confirmKeys: [13, 44],
2017-02-17 19:31:21 -07:00
trimValue: true,
2016-12-09 18:53:08 +03:00
});
ajaxify.data.category.tagWhitelist.forEach(function (tag) {
tagEl.tagsinput('add', tag);
});
2017-02-18 15:05:36 -07:00
tagEl.on('itemAdded itemRemoved', function () {
2016-12-09 18:53:08 +03:00
modified(tagEl);
});
}
Category.setupPrivilegeTable = function () {
$('.privilege-table-container').on('change', 'input[type="checkbox"]', function () {
2017-02-17 20:20:42 -07:00
var checkboxEl = $(this);
var privilege = checkboxEl.parent().attr('data-privilege');
var state = checkboxEl.prop('checked');
var rowEl = checkboxEl.parents('tr');
var member = rowEl.attr('data-group-name') || rowEl.attr('data-uid');
var isPrivate = parseInt(rowEl.attr('data-private') || 0, 10);
var isGroup = rowEl.attr('data-group-name') !== undefined;
if (member) {
if (isGroup && privilege === 'groups:moderate' && !isPrivate && state) {
bootbox.confirm('[[admin/manage/categories:alert.confirm-moderate]]', function (confirm) {
if (confirm) {
Category.setPrivilege(member, privilege, state, checkboxEl);
} else {
2017-02-18 18:55:33 -07:00
checkboxEl.prop('checked', !checkboxEl.prop('checked'));
}
});
} else {
Category.setPrivilege(member, privilege, state, checkboxEl);
}
} else {
app.alertError('[[error:invalid-data]]');
}
});
$('.privilege-table-container').on('click', '[data-action="search.user"]', Category.addUserToPrivilegeTable);
$('.privilege-table-container').on('click', '[data-action="search.group"]', Category.addGroupToPrivilegeTable);
2016-01-12 15:47:09 +02:00
$('.privilege-table-container').on('click', '[data-action="copyToChildren"]', Category.copyPrivilegesToChildren);
2016-05-23 12:59:33 +03:00
$('.privilege-table-container').on('click', '[data-action="copyPrivilegesFrom"]', Category.copyPrivilegesFromCategory);
Category.exposeAssumedPrivileges();
};
Category.refreshPrivilegeTable = function () {
socket.emit('admin.categories.getPrivilegeSettings', ajaxify.data.category.cid, function (err, privileges) {
if (err) {
return app.alertError(err.message);
}
templates.parse('admin/partials/categories/privileges', {
2017-02-17 19:31:21 -07:00
privileges: privileges,
}, function (html) {
translator.translate(html, function (html) {
$('.privilege-table-container').html(html);
Category.exposeAssumedPrivileges();
});
});
});
};
Category.exposeAssumedPrivileges = function () {
/*
If registered-users has a privilege enabled, then all users and groups of that privilege
should be assumed to have that privilege as well, even if not set in the db, so reflect
this arrangement in the table
*/
var privs = [];
$('.privilege-table tr[data-group-name="registered-users"] td input[type="checkbox"]').parent().each(function (idx, el) {
if ($(el).find('input').prop('checked')) {
privs.push(el.getAttribute('data-privilege'));
}
});
for (var x = 0, numPrivs = privs.length; x < numPrivs; x += 1) {
var inputs = $('.privilege-table tr[data-group-name]:not([data-group-name="registered-users"],[data-group-name="guests"]) td[data-privilege="' + privs[x] + '"] input');
inputs.each(function (idx, el) {
if (!el.checked) {
el.indeterminate = true;
}
});
}
};
Category.setPrivilege = function (member, privilege, state, checkboxEl) {
socket.emit('admin.categories.setPrivilege', {
2015-07-06 14:33:43 -04:00
cid: ajaxify.data.category.cid,
privilege: privilege,
set: state,
2017-02-17 19:31:21 -07:00
member: member,
}, function (err) {
if (err) {
return app.alertError(err.message);
}
checkboxEl.replaceWith('<i class="fa fa-spin fa-spinner"></i>');
Category.refreshPrivilegeTable();
});
};
Category.launchParentSelector = function () {
socket.emit('categories.get', function (err, categories) {
2015-09-15 12:58:19 -04:00
if (err) {
return app.alertError(err.message);
}
categories = categories.filter(function (category) {
2015-10-13 13:58:25 -04:00
return category && !category.disabled && parseInt(category.cid, 10) !== parseInt(ajaxify.data.category.cid, 10);
2015-09-15 12:58:19 -04:00
});
2015-09-20 15:38:54 -04:00
templates.parse('partials/category_list', {
2017-02-17 19:31:21 -07:00
categories: categories,
}, function (html) {
var modal = bootbox.dialog({
message: html,
2017-02-17 19:31:21 -07:00
title: '[[admin/manage/categories:alert.set-parent-category]]',
});
modal.find('li[data-cid]').on('click', function () {
2017-02-17 20:20:42 -07:00
var parentCid = $(this).attr('data-cid');
var payload = {};
payload[ajaxify.data.category.cid] = {
2017-02-17 19:31:21 -07:00
parentCid: parentCid,
};
socket.emit('admin.categories.update', payload, function (err) {
if (err) {
return app.alertError(err.message);
}
var parent = categories.filter(function (category) {
return category && parseInt(category.cid, 10) === parseInt(parentCid, 10);
2015-09-20 15:38:54 -04:00
});
parent = parent[0];
modal.modal('hide');
$('button[data-action="removeParent"]').parent().removeClass('hide');
$('button[data-action="setParent"]').addClass('hide');
var buttonHtml = '<i class="fa ' + parent.icon + '"></i> ' + parent.name;
$('button[data-action="changeParent"]').html(buttonHtml).parent().removeClass('hide');
});
});
});
});
};
Category.addUserToPrivilegeTable = function () {
var modal = bootbox.dialog({
title: '[[admin/manage/categories:alert.find-user]]',
message: '<input class="form-control input-lg" placeholder="[[admin/manage/categories:alert.user-search]]" />',
2017-02-17 19:31:21 -07:00
show: true,
});
modal.on('shown.bs.modal', function () {
2015-06-15 16:03:38 -04:00
var inputEl = modal.find('input');
autocomplete.user(inputEl, function (ev, ui) {
socket.emit('admin.categories.setPrivilege', {
2015-07-06 14:33:43 -04:00
cid: ajaxify.data.category.cid,
privilege: ['find', 'read', 'topics:read'],
set: true,
2017-02-17 19:31:21 -07:00
member: ui.item.user.uid,
}, function (err) {
if (err) {
return app.alertError(err.message);
}
Category.refreshPrivilegeTable();
modal.modal('hide');
});
});
});
};
Category.addGroupToPrivilegeTable = function () {
var modal = bootbox.dialog({
title: '[[admin/manage/categories:alert.find-group]]',
message: '<input class="form-control input-lg" placeholder="[[admin/manage/categories:alert.group-search]]" />',
2017-02-17 19:31:21 -07:00
show: true,
});
modal.on('shown.bs.modal', function () {
2015-06-15 16:03:38 -04:00
var inputEl = modal.find('input');
autocomplete.group(inputEl, function (ev, ui) {
socket.emit('admin.categories.setPrivilege', {
2015-07-06 14:33:43 -04:00
cid: ajaxify.data.category.cid,
2016-06-01 08:52:54 -04:00
privilege: ['groups:find', 'groups:read', 'groups:topics:read'],
set: true,
2017-02-17 19:31:21 -07:00
member: ui.item.group.name,
}, function (err) {
if (err) {
return app.alertError(err.message);
}
Category.refreshPrivilegeTable();
modal.modal('hide');
});
});
});
};
Category.copyPrivilegesToChildren = function () {
socket.emit('admin.categories.copyPrivilegesToChildren', ajaxify.data.category.cid, function (err) {
2016-01-12 15:47:09 +02:00
if (err) {
return app.alertError(err.message);
}
app.alertSuccess('Privileges copied!');
});
};
Category.copyPrivilegesFromCategory = function () {
selectCategoryModal(function (cid) {
2017-02-18 12:30:49 -07:00
socket.emit('admin.categories.copyPrivilegesFrom', { toCid: ajaxify.data.category.cid, fromCid: cid }, function (err) {
2016-05-23 12:59:33 +03:00
if (err) {
return app.alertError(err.message);
}
ajaxify.refresh();
});
});
};
function selectCategoryModal(callback) {
socket.emit('admin.categories.getNames', function (err, categories) {
2016-05-23 12:59:33 +03:00
if (err) {
return app.alertError(err.message);
}
templates.parse('admin/partials/categories/select-category', {
2017-02-17 19:31:21 -07:00
categories: categories,
}, function (html) {
translator.translate(html, function (html) {
var modal = bootbox.dialog({
title: 'Select a Category',
message: html,
buttons: {
save: {
label: 'Copy',
className: 'btn-primary',
2017-02-17 19:31:21 -07:00
callback: submit,
},
},
});
2016-05-23 12:59:33 +03:00
2017-02-18 18:55:33 -07:00
function submit() {
var formData = modal.find('form').serializeObject();
callback(formData['select-cid']);
modal.modal('hide');
return false;
}
modal.find('form').on('submit', submit);
});
2016-05-23 12:59:33 +03:00
});
});
}
2014-12-30 13:04:31 -05:00
return Category;
2017-02-18 02:30:48 -07:00
});