mirror of
https://github.com/zulip/zulip.git
synced 2025-11-15 11:22:04 +00:00
Extract settings_filters.js.
This commit is contained in:
@@ -16,29 +16,6 @@ exports.show_or_hide_menu_item = function () {
|
||||
}
|
||||
};
|
||||
|
||||
exports.populate_filters = function (filters_data) {
|
||||
if (!meta.loaded) {
|
||||
return;
|
||||
}
|
||||
|
||||
var filters_table = $("#admin_filters_table").expectOne();
|
||||
filters_table.find("tr.filter_row").remove();
|
||||
_.each(filters_data, function (filter) {
|
||||
filters_table.append(
|
||||
templates.render(
|
||||
"admin_filter_list", {
|
||||
filter: {
|
||||
pattern: filter[0],
|
||||
url_format_string: filter[1],
|
||||
id: filter[2],
|
||||
},
|
||||
}
|
||||
)
|
||||
);
|
||||
});
|
||||
loading.destroy_indicator($('#admin_page_filters_loading_indicator'));
|
||||
};
|
||||
|
||||
function _setup_page() {
|
||||
var options = {
|
||||
realm_name: page_params.realm_name,
|
||||
@@ -89,9 +66,6 @@ function _setup_page() {
|
||||
|
||||
$("#id_realm_default_language").val(page_params.realm_default_language);
|
||||
|
||||
// create loading indicators
|
||||
loading.make_indicator($('#admin_page_filters_loading_indicator'));
|
||||
|
||||
// We set this flag before we're fully loaded so that the populate
|
||||
// methods don't short-circuit.
|
||||
meta.loaded = true;
|
||||
@@ -100,72 +74,7 @@ function _setup_page() {
|
||||
settings_emoji.set_up();
|
||||
settings_users.set_up();
|
||||
settings_streams.set_up();
|
||||
|
||||
// Populate filters table
|
||||
exports.populate_filters(page_params.realm_filters);
|
||||
|
||||
$('.admin_filters_table').on('click', '.delete', function (e) {
|
||||
e.preventDefault();
|
||||
e.stopPropagation();
|
||||
var btn = $(this);
|
||||
|
||||
channel.del({
|
||||
url: '/json/realm/filters/' + encodeURIComponent(btn.attr('data-filter-id')),
|
||||
error: function (xhr) {
|
||||
if (xhr.status.toString().charAt(0) === "4") {
|
||||
btn.closest("td").html(
|
||||
$("<p>").addClass("text-error").text($.parseJSON(xhr.responseText).msg)
|
||||
);
|
||||
} else {
|
||||
btn.text(i18n.t("Failed!"));
|
||||
}
|
||||
},
|
||||
success: function () {
|
||||
var row = btn.parents('tr');
|
||||
row.remove();
|
||||
},
|
||||
});
|
||||
});
|
||||
|
||||
$(".organization").on("submit", "form.admin-filter-form", function (e) {
|
||||
e.preventDefault();
|
||||
e.stopPropagation();
|
||||
var filter_status = $('#admin-filter-status');
|
||||
var pattern_status = $('#admin-filter-pattern-status');
|
||||
var format_status = $('#admin-filter-format-status');
|
||||
filter_status.hide();
|
||||
pattern_status.hide();
|
||||
format_status.hide();
|
||||
var filter = {};
|
||||
_.each($(this).serializeArray(), function (obj) {
|
||||
filter[obj.name] = obj.value;
|
||||
});
|
||||
|
||||
channel.post({
|
||||
url: "/json/realm/filters",
|
||||
data: $(this).serialize(),
|
||||
success: function (data) {
|
||||
filter.id = data.id;
|
||||
ui_report.success(i18n.t("Custom filter added!"), filter_status);
|
||||
},
|
||||
error: function (xhr) {
|
||||
var errors = $.parseJSON(xhr.responseText).errors;
|
||||
if (errors.pattern !== undefined) {
|
||||
xhr.responseText = JSON.stringify({msg: errors.pattern});
|
||||
ui_report.error(i18n.t("Failed"), xhr, pattern_status);
|
||||
}
|
||||
if (errors.url_format_string !== undefined) {
|
||||
xhr.responseText = JSON.stringify({msg: errors.url_format_string});
|
||||
ui_report.error(i18n.t("Failed"), xhr, format_status);
|
||||
}
|
||||
if (errors.__all__ !== undefined) {
|
||||
xhr.responseText = JSON.stringify({msg: errors.__all__});
|
||||
ui_report.error(i18n.t("Failed"), xhr, filter_status);
|
||||
}
|
||||
},
|
||||
});
|
||||
});
|
||||
|
||||
settings_filters.set_up();
|
||||
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user