Extract settings_streams.js.

This commit is contained in:
Steve Howell 2017-04-08 12:02:08 -07:00 committed by Tim Abbott
parent 70afb59cff
commit 3e37f64f71
6 changed files with 223 additions and 194 deletions

View File

@ -42,6 +42,7 @@
"settings_emoji": false, "settings_emoji": false,
"settings_org": false, "settings_org": false,
"settings_users": false, "settings_users": false,
"settings_streams": false,
"settings": false, "settings": false,
"resize": false, "resize": false,
"loading": false, "loading": false,

View File

@ -412,7 +412,7 @@ with_overrides(function () {
with_overrides(function (override) { with_overrides(function (override) {
// default_streams // default_streams
var event = event_fixtures.default_streams; var event = event_fixtures.default_streams;
override('admin.update_default_streams_table', noop); override('settings_streams.update_default_streams_table', noop);
dispatch(event); dispatch(event);
assert_same(page_params.realm_default_streams, event.default_streams); assert_same(page_params.realm_default_streams, event.default_streams);
@ -634,7 +634,7 @@ with_overrides(function (override) {
global.with_stub(function (stub) { global.with_stub(function (stub) {
override('stream_events.update_property', stub.f); override('stream_events.update_property', stub.f);
override('admin.update_default_streams_table', noop); override('settings_streams.update_default_streams_table', noop);
dispatch(event); dispatch(event);
var args = stub.get_args('stream_id', 'property', 'value'); var args = stub.get_args('stream_id', 'property', 'value');
assert_same(args.stream_id, event.stream_id); assert_same(args.stream_id, event.stream_id);

View File

@ -4,7 +4,6 @@ var meta = {
loaded: false, loaded: false,
}; };
var exports = {}; var exports = {};
var all_streams = [];
exports.show_or_hide_menu_item = function () { exports.show_or_hide_menu_item = function () {
var item = $('.admin-menu-item').expectOne(); var item = $('.admin-menu-item').expectOne();
@ -17,121 +16,6 @@ exports.show_or_hide_menu_item = function () {
} }
}; };
function failed_listing_streams(xhr) {
ui_report.error(i18n.t("Error listing streams"), xhr, $("#organization-status"));
}
function populate_streams(streams_data) {
var streams_table = $("#admin_streams_table").expectOne();
all_streams = streams_data;
streams_table.find("tr.stream_row").remove();
_.each(streams_data.streams, function (stream) {
streams_table.append(templates.render("admin_streams_list", {stream: stream}));
});
loading.destroy_indicator($('#admin_page_streams_loading_indicator'));
}
exports.build_default_stream_table = function (streams_data) {
var self = {};
self.row_dict = new Dict();
function set_up_remove_click_hander(row, stream_name) {
row.on("click", ".remove-default-stream", function (e) {
e.preventDefault();
e.stopPropagation();
channel.del({
url: '/json/default_streams'+ '?' + $.param({stream_name: stream_name}),
error: function (xhr) {
var button = row.find("button");
if (xhr.status.toString().charAt(0) === "4") {
button.closest("td").html(
$("<p>").addClass("text-error").text(JSON.parse(xhr.responseText).msg)
);
} else {
button.text(i18n.t("Failed!"));
}
},
success: function () {
row.remove();
},
});
});
}
(function () {
var table = $("#admin_default_streams_table").expectOne();
_.each(streams_data, function (stream) {
var row = $(templates.render("admin_default_streams_list", {stream: stream}));
set_up_remove_click_hander(row, stream.name);
self.row_dict.set(stream.stream_id, row);
table.append(row);
});
loading.destroy_indicator($('#admin_page_default_streams_loading_indicator'));
}());
self.remove = function (stream_id) {
if (self.row_dict.has(stream_id)) {
var row = self.row_dict.get(stream_id);
row.remove();
}
};
return self;
};
var default_stream_table;
exports.remove_default_stream = function (stream_id) {
if (default_stream_table) {
default_stream_table.remove(stream_id);
}
};
function get_non_default_streams_names(streams_data) {
var non_default_streams_names = [];
var default_streams_names = [];
_.each(page_params.realm_default_streams, function (default_stream) {
default_streams_names.push(default_stream.name);
});
_.each(streams_data.streams, function (stream) {
if (default_streams_names.indexOf(stream.name) < 0) {
non_default_streams_names.push(stream.name);
}
});
return non_default_streams_names;
}
exports.update_default_streams_table = function () {
if (/#*organization/.test(window.location.hash) ||
/#*settings/.test(window.location.hash)) {
$("#admin_default_streams_table").expectOne().find("tr.default_stream_row").remove();
default_stream_table = exports.build_default_stream_table(
page_params.realm_default_streams);
}
};
function make_stream_default(stream_name) {
var data = {
stream_name: stream_name,
};
channel.post({
url: '/json/default_streams',
data: data,
error: function (xhr) {
if (xhr.status.toString().charAt(0) === "4") {
$(".active_stream_row button").closest("td").html(
$("<p>").addClass("text-error").text(JSON.parse(xhr.responseText).msg));
} else {
$(".active_stream_row button").text(i18n.t("Failed!"));
}
},
});
}
exports.populate_filters = function (filters_data) { exports.populate_filters = function (filters_data) {
if (!meta.loaded) { if (!meta.loaded) {
return; return;
@ -206,18 +90,8 @@ function _setup_page() {
$("#id_realm_default_language").val(page_params.realm_default_language); $("#id_realm_default_language").val(page_params.realm_default_language);
// create loading indicators // create loading indicators
loading.make_indicator($('#admin_page_streams_loading_indicator'));
loading.make_indicator($('#admin_page_filters_loading_indicator')); loading.make_indicator($('#admin_page_filters_loading_indicator'));
// Populate streams table
channel.get({
url: '/json/streams?include_public=true&include_subscribed=true&include_default=true',
timeout: 10*1000,
idempotent: true,
success: populate_streams,
error: failed_listing_streams,
});
// We set this flag before we're fully loaded so that the populate // We set this flag before we're fully loaded so that the populate
// methods don't short-circuit. // methods don't short-circuit.
meta.loaded = true; meta.loaded = true;
@ -225,73 +99,11 @@ function _setup_page() {
settings_org.set_up(); settings_org.set_up();
settings_emoji.set_up(); settings_emoji.set_up();
settings_users.set_up(); settings_users.set_up();
settings_streams.set_up();
exports.update_default_streams_table();
// Populate filters table // Populate filters table
exports.populate_filters(page_params.realm_filters); exports.populate_filters(page_params.realm_filters);
$(".admin_stream_table").on("click", ".deactivate", function (e) {
e.preventDefault();
e.stopPropagation();
$(".active_stream_row").removeClass("active_stream_row");
var row = $(e.target).closest(".stream_row");
row.addClass("active_stream_row");
var stream_name = row.find('.stream_name').text();
$("#deactivation_stream_modal .stream_name").text(stream_name);
$("#deactivation_stream_modal").modal("show");
});
$('.create_default_stream').keypress(function (e) {
if (e.which === 13) {
e.preventDefault();
e.stopPropagation();
}
});
$('.create_default_stream').typeahead({
items: 5,
fixed: true,
source: function () {
return get_non_default_streams_names(all_streams);
},
highlight: true,
updater: function (stream_name) {
make_stream_default(stream_name);
},
});
$("#do_deactivate_stream_button").click(function () {
if ($("#deactivation_stream_modal .stream_name").text() !== $(".active_stream_row").find('.stream_name').text()) {
blueslip.error("Stream deactivation canceled due to non-matching fields.");
ui_report.message("Deactivation encountered an error. Please reload and try again.",
$("#home-error"), 'alert-error');
}
$("#deactivation_stream_modal").modal("hide");
$(".active_stream_row button").prop("disabled", true).text(i18n.t("Working…"));
var stream_name = $(".active_stream_row").find('.stream_name').text();
var stream_id = stream_data.get_sub(stream_name).stream_id;
channel.del({
url: '/json/streams/' + stream_id,
error: function (xhr) {
if (xhr.status.toString().charAt(0) === "4") {
$(".active_stream_row button").closest("td").html(
$("<p>").addClass("text-error").text(JSON.parse(xhr.responseText).msg)
);
} else {
$(".active_stream_row button").text(i18n.t("Failed!"));
}
},
success: function () {
var row = $(".active_stream_row");
row.remove();
},
});
});
$('.admin_filters_table').on('click', '.delete', function (e) { $('.admin_filters_table').on('click', '.delete', function (e) {
e.preventDefault(); e.preventDefault();
e.stopPropagation(); e.stopPropagation();

View File

@ -20,7 +20,7 @@ function dispatch_normal_event(event) {
case 'default_streams': case 'default_streams':
page_params.realm_default_streams = event.default_streams; page_params.realm_default_streams = event.default_streams;
admin.update_default_streams_table(); settings_streams.update_default_streams_table();
break; break;
case 'hotspots': case 'hotspots':
@ -181,7 +181,7 @@ function dispatch_normal_event(event) {
event.property, event.property,
event.value event.value
); );
admin.update_default_streams_table(); settings_streams.update_default_streams_table();
} else if (event.op === 'create') { } else if (event.op === 'create') {
stream_data.create_streams(event.streams); stream_data.create_streams(event.streams);
} else if (event.op === 'delete') { } else if (event.op === 'delete') {
@ -191,7 +191,7 @@ function dispatch_normal_event(event) {
} }
subs.remove_stream(stream.stream_id); subs.remove_stream(stream.stream_id);
stream_data.delete_sub(stream.stream_id); stream_data.delete_sub(stream.stream_id);
admin.remove_default_stream(stream.stream_id); settings_streams.remove_default_stream(stream.stream_id);
stream_data.remove_default_stream(stream.stream_id); stream_data.remove_default_stream(stream.stream_id);
}); });
} }

View File

@ -0,0 +1,215 @@
var settings_streams = (function () {
var exports = {};
var meta = {
loaded: false,
};
var all_streams = [];
function failed_listing_streams(xhr) {
ui_report.error(i18n.t("Error listing streams"), xhr, $("#organization-status"));
}
function populate_streams(streams_data) {
var streams_table = $("#admin_streams_table").expectOne();
all_streams = streams_data;
streams_table.find("tr.stream_row").remove();
_.each(streams_data.streams, function (stream) {
streams_table.append(templates.render("admin_streams_list", {stream: stream}));
});
loading.destroy_indicator($('#admin_page_streams_loading_indicator'));
}
exports.build_default_stream_table = function (streams_data) {
var self = {};
self.row_dict = new Dict();
function set_up_remove_click_hander(row, stream_name) {
row.on("click", ".remove-default-stream", function (e) {
e.preventDefault();
e.stopPropagation();
channel.del({
url: '/json/default_streams'+ '?' + $.param({stream_name: stream_name}),
error: function (xhr) {
var button = row.find("button");
if (xhr.status.toString().charAt(0) === "4") {
button.closest("td").html(
$("<p>").addClass("text-error").text(JSON.parse(xhr.responseText).msg)
);
} else {
button.text(i18n.t("Failed!"));
}
},
success: function () {
row.remove();
},
});
});
}
(function () {
var table = $("#admin_default_streams_table").expectOne();
_.each(streams_data, function (stream) {
var row = $(templates.render("admin_default_streams_list", {stream: stream}));
set_up_remove_click_hander(row, stream.name);
self.row_dict.set(stream.stream_id, row);
table.append(row);
});
loading.destroy_indicator($('#admin_page_default_streams_loading_indicator'));
}());
self.remove = function (stream_id) {
if (self.row_dict.has(stream_id)) {
var row = self.row_dict.get(stream_id);
row.remove();
}
};
return self;
};
var default_stream_table;
exports.remove_default_stream = function (stream_id) {
if (default_stream_table) {
default_stream_table.remove(stream_id);
}
};
function get_non_default_streams_names(streams_data) {
var non_default_streams_names = [];
var default_streams_names = [];
_.each(page_params.realm_default_streams, function (default_stream) {
default_streams_names.push(default_stream.name);
});
_.each(streams_data.streams, function (stream) {
if (default_streams_names.indexOf(stream.name) < 0) {
non_default_streams_names.push(stream.name);
}
});
return non_default_streams_names;
}
exports.update_default_streams_table = function () {
if (/#*organization/.test(window.location.hash) ||
/#*settings/.test(window.location.hash)) {
$("#admin_default_streams_table").expectOne().find("tr.default_stream_row").remove();
default_stream_table = exports.build_default_stream_table(
page_params.realm_default_streams);
}
};
function make_stream_default(stream_name) {
var data = {
stream_name: stream_name,
};
channel.post({
url: '/json/default_streams',
data: data,
error: function (xhr) {
if (xhr.status.toString().charAt(0) === "4") {
$(".active_stream_row button").closest("td").html(
$("<p>").addClass("text-error").text(JSON.parse(xhr.responseText).msg));
} else {
$(".active_stream_row button").text(i18n.t("Failed!"));
}
},
});
}
exports.set_up = function () {
loading.make_indicator($('#admin_page_streams_loading_indicator'));
// Populate streams table
channel.get({
url: '/json/streams?include_public=true&include_subscribed=true&include_default=true',
timeout: 10*1000,
idempotent: true,
success: exports.on_load_success,
error: failed_listing_streams,
});
};
exports.on_load_success = function (streams_data) {
meta.loaded = true;
populate_streams(streams_data);
exports.update_default_streams_table();
$(".admin_stream_table").on("click", ".deactivate", function (e) {
e.preventDefault();
e.stopPropagation();
$(".active_stream_row").removeClass("active_stream_row");
var row = $(e.target).closest(".stream_row");
row.addClass("active_stream_row");
var stream_name = row.find('.stream_name').text();
$("#deactivation_stream_modal .stream_name").text(stream_name);
$("#deactivation_stream_modal").modal("show");
});
$('.create_default_stream').keypress(function (e) {
if (e.which === 13) {
e.preventDefault();
e.stopPropagation();
}
});
$('.create_default_stream').typeahead({
items: 5,
fixed: true,
source: function () {
return get_non_default_streams_names(all_streams);
},
highlight: true,
updater: function (stream_name) {
make_stream_default(stream_name);
},
});
$("#do_deactivate_stream_button").click(function () {
if ($("#deactivation_stream_modal .stream_name").text() !== $(".active_stream_row").find('.stream_name').text()) {
blueslip.error("Stream deactivation canceled due to non-matching fields.");
ui_report.message("Deactivation encountered an error. Please reload and try again.",
$("#home-error"), 'alert-error');
}
$("#deactivation_stream_modal").modal("hide");
$(".active_stream_row button").prop("disabled", true).text(i18n.t("Working…"));
var stream_name = $(".active_stream_row").find('.stream_name').text();
var stream_id = stream_data.get_sub(stream_name).stream_id;
channel.del({
url: '/json/streams/' + stream_id,
error: function (xhr) {
if (xhr.status.toString().charAt(0) === "4") {
$(".active_stream_row button").closest("td").html(
$("<p>").addClass("text-error").text(JSON.parse(xhr.responseText).msg)
);
} else {
$(".active_stream_row button").text(i18n.t("Failed!"));
}
},
success: function () {
var row = $(".active_stream_row");
row.remove();
},
});
});
};
return exports;
}());
if (typeof module !== 'undefined') {
module.exports = settings_streams;
}

View File

@ -916,6 +916,7 @@ JS_SPECS = {
'js/settings_emoji.js', 'js/settings_emoji.js',
'js/settings_org.js', 'js/settings_org.js',
'js/settings_users.js', 'js/settings_users.js',
'js/settings_streams.js',
'js/settings.js', 'js/settings.js',
'js/admin.js', 'js/admin.js',
'js/tab_bar.js', 'js/tab_bar.js',