settings_components: Split functions to improve typechecking.

This commit is contained in:
afeefuddin
2024-05-21 01:06:38 +05:30
committed by Tim Abbott
parent 7355aa3922
commit 9d33c94f2d
8 changed files with 436 additions and 241 deletions

View File

@@ -93,63 +93,9 @@ type StreamSettingProperties = keyof StreamSubscription | "stream_privacy" | "is
type valueof<T> = T[keyof T]; type valueof<T> = T[keyof T];
export function get_property_value( export function get_realm_settings_property_value(
property_name: property_name: RealmSettingProperties,
| RealmSettingProperties ): valueof<RealmSetting> {
| StreamSettingProperties
| keyof UserGroup
| keyof CustomProfileField
| RealmUserSettingDefaultProperties,
for_realm_default_settings?: boolean,
sub?: StreamSubscription,
group?: UserGroup,
custom_profile_field?: CustomProfileField,
):
| valueof<RealmSetting>
| valueof<StreamSubscription>
| valueof<UserGroup>
| valueof<CustomProfileField>
| valueof<RealmUserSettingDefaultType> {
if (for_realm_default_settings) {
// realm_user_default_settings are stored in a separate object.
if (property_name === "twenty_four_hour_time") {
return JSON.stringify(realm_user_settings_defaults.twenty_four_hour_time);
}
if (
property_name === "email_notifications_batching_period_seconds" ||
property_name === "email_notification_batching_period_edit_minutes"
) {
return realm_user_settings_defaults.email_notifications_batching_period_seconds;
}
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
return realm_user_settings_defaults[property_name as keyof RealmUserSettingDefaultType];
}
if (sub) {
if (property_name === "stream_privacy") {
return stream_data.get_stream_privacy_policy(sub.stream_id);
}
if (property_name === "is_default_stream") {
return stream_data.is_default_stream_id(sub.stream_id);
}
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
return sub[property_name as keyof StreamSubscription];
}
if (group) {
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
return group[property_name as keyof UserGroup];
}
if (custom_profile_field) {
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
const value = custom_profile_field[property_name as keyof CustomProfileField];
if (property_name === "display_in_profile_summary" && value === undefined) {
return false;
}
return value;
}
if (property_name === "realm_org_join_restrictions") { if (property_name === "realm_org_join_restrictions") {
if (realm.realm_emails_restricted_to_domains) { if (realm.realm_emails_restricted_to_domains) {
return "only_selected_domain"; return "only_selected_domain";
@@ -163,9 +109,53 @@ export function get_property_value(
if (property_name === "realm_authentication_methods") { if (property_name === "realm_authentication_methods") {
return JSON.stringify(realm_authentication_methods_to_boolean_dict()); return JSON.stringify(realm_authentication_methods_to_boolean_dict());
} }
return realm[property_name];
}
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions export function get_stream_settings_property_value(
return realm[property_name as keyof RealmSetting] as valueof<RealmSetting>; property_name: StreamSettingProperties,
sub: StreamSubscription,
): valueof<StreamSubscription> {
if (property_name === "stream_privacy") {
return stream_data.get_stream_privacy_policy(sub.stream_id);
}
if (property_name === "is_default_stream") {
return stream_data.is_default_stream_id(sub.stream_id);
}
return sub[property_name];
}
export function get_group_property_value(
property_name: keyof UserGroup,
group: UserGroup,
): valueof<UserGroup> {
return group[property_name];
}
export function get_custom_profile_property_value(
property_name: keyof CustomProfileField,
custom_profile_field: CustomProfileField,
): valueof<CustomProfileField> {
const value = custom_profile_field[property_name];
if (property_name === "display_in_profile_summary" && value === undefined) {
return false;
}
return value;
}
export function get_realm_default_setting_property_value(
property_name: RealmUserSettingDefaultProperties,
): valueof<RealmUserSettingDefaultType> {
if (property_name === "twenty_four_hour_time") {
return JSON.stringify(realm_user_settings_defaults.twenty_four_hour_time);
}
if (
property_name === "email_notifications_batching_period_seconds" ||
property_name === "email_notification_batching_period_edit_minutes"
) {
return realm_user_settings_defaults.email_notifications_batching_period_seconds;
}
return realm_user_settings_defaults[property_name];
} }
export function realm_authentication_methods_to_boolean_dict(): Record<string, boolean> { export function realm_authentication_methods_to_boolean_dict(): Record<string, boolean> {
@@ -231,7 +221,7 @@ export function set_property_dropdown_value(
property_name: keyof simple_dropdown_realm_settings, property_name: keyof simple_dropdown_realm_settings,
): void { ): void {
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions // eslint-disable-next-line @typescript-eslint/consistent-type-assertions
const property_value = get_property_value( const property_value = get_realm_settings_property_value(
property_name, property_name,
) as valueof<simple_dropdown_realm_settings>; ) as valueof<simple_dropdown_realm_settings>;
$(`#id_${CSS.escape(property_name)}`).val(property_value); $(`#id_${CSS.escape(property_name)}`).val(property_value);
@@ -805,36 +795,13 @@ function get_time_limit_setting_value(
return parse_time_limit($custom_input_elem); return parse_time_limit($custom_input_elem);
} }
type setting_property_type = export function check_realm_settings_property_changed(elem: HTMLElement): boolean {
| RealmSettingProperties
| StreamSettingProperties
| keyof UserGroup
| keyof CustomProfileField
| RealmUserSettingDefaultProperties;
export function check_property_changed(
elem: HTMLElement,
for_realm_default_settings: boolean,
sub: StreamSubscription | undefined,
group: UserGroup | undefined,
custom_profile_field: CustomProfileField | undefined,
): boolean {
const $elem = $(elem); const $elem = $(elem);
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions // eslint-disable-next-line @typescript-eslint/consistent-type-assertions
const property_name = extract_property_name( const property_name = extract_property_name($elem) as RealmSettingProperties;
$elem, const current_val = get_realm_settings_property_value(property_name);
for_realm_default_settings,
) as setting_property_type;
const current_val = get_property_value(
property_name,
for_realm_default_settings,
sub,
group,
custom_profile_field,
);
let proposed_val; let proposed_val;
switch (property_name) { switch (property_name) {
case "realm_authentication_methods": case "realm_authentication_methods":
proposed_val = get_input_element_value(elem, "auth-methods"); proposed_val = get_input_element_value(elem, "auth-methods");
@@ -843,13 +810,10 @@ export function check_property_changed(
case "realm_signup_announcements_stream_id": case "realm_signup_announcements_stream_id":
case "realm_zulip_update_announcements_stream_id": case "realm_zulip_update_announcements_stream_id":
case "realm_default_code_block_language": case "realm_default_code_block_language":
case "can_remove_subscribers_group":
case "realm_create_multiuse_invite_group": case "realm_create_multiuse_invite_group":
case "can_mention_group":
case "realm_can_access_all_users_group": case "realm_can_access_all_users_group":
proposed_val = get_dropdown_list_widget_setting_value($elem); proposed_val = get_dropdown_list_widget_setting_value($elem);
break; break;
case "email_notifications_batching_period_seconds":
case "realm_message_content_edit_limit_seconds": case "realm_message_content_edit_limit_seconds":
case "realm_message_content_delete_limit_seconds": case "realm_message_content_delete_limit_seconds":
case "realm_move_messages_between_streams_limit_seconds": case "realm_move_messages_between_streams_limit_seconds":
@@ -859,7 +823,6 @@ export function check_property_changed(
proposed_val = get_time_limit_setting_value($(elem), false); proposed_val = get_time_limit_setting_value($(elem), false);
break; break;
case "realm_message_retention_days": case "realm_message_retention_days":
case "message_retention_days":
assert(elem instanceof HTMLSelectElement); assert(elem instanceof HTMLSelectElement);
proposed_val = get_message_retention_setting_value($(elem), false); proposed_val = get_message_retention_setting_value($(elem), false);
break; break;
@@ -872,13 +835,99 @@ export function check_property_changed(
"#org-notifications .language_selection_widget .language_selection_button span", "#org-notifications .language_selection_widget .language_selection_button span",
).attr("data-language-code"); ).attr("data-language-code");
break; break;
case "emojiset": default:
case "user_list_style": if (current_val !== undefined) {
proposed_val = get_input_element_value(elem, typeof current_val);
} else {
blueslip.error("Element refers to unknown property", {property_name});
}
}
return current_val !== proposed_val;
}
export function check_stream_settings_property_changed(
elem: HTMLElement,
sub: StreamSubscription,
): boolean {
const $elem = $(elem);
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
const property_name = extract_property_name($elem) as StreamSettingProperties;
const current_val = get_stream_settings_property_value(property_name, sub);
let proposed_val;
switch (property_name) {
case "can_remove_subscribers_group":
proposed_val = get_dropdown_list_widget_setting_value($elem);
break;
case "message_retention_days":
assert(elem instanceof HTMLSelectElement);
proposed_val = get_message_retention_setting_value($(elem), false);
break;
case "stream_privacy": case "stream_privacy":
proposed_val = get_input_element_value(elem, "radio-group"); proposed_val = get_input_element_value(elem, "radio-group");
break; break;
case "field_data": default:
proposed_val = get_input_element_value(elem, "field-data-setting"); if (current_val !== undefined) {
proposed_val = get_input_element_value(elem, typeof current_val);
} else {
blueslip.error("Element refers to unknown property", {property_name});
}
}
return current_val !== proposed_val;
}
export function check_group_property_changed(elem: HTMLElement, group: UserGroup): boolean {
const $elem = $(elem);
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
const property_name = extract_property_name($elem) as keyof UserGroup;
const current_val = get_group_property_value(property_name, group);
let proposed_val;
switch (property_name) {
case "can_mention_group":
proposed_val = get_dropdown_list_widget_setting_value($elem);
break;
default:
if (current_val !== undefined) {
proposed_val = get_input_element_value(elem, typeof current_val);
} else {
blueslip.error("Element refers to unknown property", {property_name});
}
}
return current_val !== proposed_val;
}
export function check_custom_profile_property_changed(
elem: HTMLElement,
custom_profile_field: CustomProfileField,
): boolean {
const $elem = $(elem);
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
const property_name = extract_property_name($elem) as keyof CustomProfileField;
const current_val = get_custom_profile_property_value(property_name, custom_profile_field);
let proposed_val;
if (property_name === "field_data") {
proposed_val = get_input_element_value(elem, "field-data-setting");
} else if (current_val !== undefined) {
proposed_val = get_input_element_value(elem, typeof current_val);
} else {
blueslip.error("Element refers to unknown property", {property_name});
}
return current_val !== proposed_val;
}
export function check_realm_default_settings_property_changed(elem: HTMLElement): boolean {
const $elem = $(elem);
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
const property_name = extract_property_name($elem, true) as RealmUserSettingDefaultProperties;
const current_val = get_realm_default_setting_property_value(property_name);
let proposed_val;
switch (property_name) {
case "emojiset":
case "user_list_style":
proposed_val = get_input_element_value(elem, "radio-group");
break;
case "email_notifications_batching_period_seconds":
assert(elem instanceof HTMLSelectElement);
proposed_val = get_time_limit_setting_value($(elem), false);
break; break;
default: default:
if (current_val !== undefined) { if (current_val !== undefined) {
@@ -916,37 +965,18 @@ function get_request_data_for_org_join_restrictions(selected_val: string): {
} }
} }
export function populate_data_for_request( export function populate_data_for_realm_settings_request(
$subsection_elem: JQuery, $subsection_elem: JQuery,
for_realm_default_settings: boolean,
sub: StreamSubscription | undefined,
group: UserGroup | undefined,
custom_profile_field?: CustomProfileField | undefined,
): Record<string, string | boolean | number> { ): Record<string, string | boolean | number> {
let data: Record<string, string | boolean | number> = {}; let data: Record<string, string | boolean | number> = {};
const properties_elements = get_subsection_property_elements($subsection_elem); const properties_elements = get_subsection_property_elements($subsection_elem);
for (const input_elem of properties_elements) { for (const input_elem of properties_elements) {
const $input_elem = $(input_elem); const $input_elem = $(input_elem);
if ( if (check_realm_settings_property_changed(input_elem)) {
check_property_changed(
input_elem,
for_realm_default_settings,
sub,
group,
custom_profile_field,
)
) {
const input_value = get_input_element_value(input_elem); const input_value = get_input_element_value(input_elem);
if (input_value !== undefined && input_value !== null) { if (input_value !== undefined && input_value !== null) {
let property_name: string; let property_name: string;
if ( if ($input_elem.attr("id")!.startsWith("id_authmethod")) {
for_realm_default_settings ||
sub !== undefined ||
group !== undefined ||
custom_profile_field !== undefined
) {
property_name = extract_property_name($input_elem, for_realm_default_settings);
} else if ($input_elem.attr("id")!.startsWith("id_authmethod")) {
// Authentication Method component IDs include authentication method name // Authentication Method component IDs include authentication method name
// for uniqueness, anchored to "id_authmethod" prefix, e.g. "id_authmethodapple_<property_name>". // for uniqueness, anchored to "id_authmethod" prefix, e.g. "id_authmethodapple_<property_name>".
// We need to strip that whole construct down to extract the actual property name. // We need to strip that whole construct down to extract the actual property name.
@@ -964,6 +994,32 @@ export function populate_data_for_request(
property_name = match_array[1]!; property_name = match_array[1]!;
} }
if (property_name === "org_join_restrictions") {
data = {
...data,
...get_request_data_for_org_join_restrictions(input_value.toString()),
};
continue;
}
data[property_name] = input_value;
}
}
}
return data;
}
export function populate_data_for_stream_settings_request(
$subsection_elem: JQuery,
sub: StreamSubscription,
): Record<string, string | boolean | number> {
let data: Record<string, string | boolean | number> = {};
const properties_elements = get_subsection_property_elements($subsection_elem);
for (const input_elem of properties_elements) {
const $input_elem = $(input_elem);
if (check_stream_settings_property_changed(input_elem, sub)) {
const input_value = get_input_element_value(input_elem);
if (input_value !== undefined && input_value !== null) {
const property_name = extract_property_name($input_elem);
if (property_name === "stream_privacy") { if (property_name === "stream_privacy") {
data = { data = {
...data, ...data,
@@ -973,22 +1029,65 @@ export function populate_data_for_request(
}; };
continue; continue;
} }
data[property_name] = input_value;
}
}
}
return data;
}
if (property_name === "can_mention_group") { export function populate_data_for_group_request(
data[property_name] = JSON.stringify({ $subsection_elem: JQuery,
new: input_value, group: UserGroup,
old: group!.can_mention_group, ): Record<string, string | boolean | number> {
}); const data: Record<string, string | boolean | number> = {};
continue; const properties_elements = get_subsection_property_elements($subsection_elem);
} for (const input_elem of properties_elements) {
const $input_elem = $(input_elem);
if (check_group_property_changed(input_elem, group)) {
const input_value = get_input_element_value(input_elem);
if (input_value !== undefined && input_value !== null) {
const property_name = extract_property_name($input_elem);
data[property_name] = JSON.stringify({
new: input_value,
old: group.can_mention_group,
});
}
}
}
return data;
}
if (property_name === "org_join_restrictions") { export function populate_data_for_custom_profile_field_request(
data = { $subsection_elem: JQuery,
...data, custom_profile_field: CustomProfileField,
...get_request_data_for_org_join_restrictions(input_value.toString()), ): Record<string, string | boolean | number> {
}; const data: Record<string, string | boolean | number> = {};
continue; const properties_elements = get_subsection_property_elements($subsection_elem);
} for (const input_elem of properties_elements) {
const $input_elem = $(input_elem);
if (check_custom_profile_property_changed(input_elem, custom_profile_field)) {
const input_value = get_input_element_value(input_elem);
if (input_value !== undefined && input_value !== null) {
const property_name = extract_property_name($input_elem);
data[property_name] = input_value;
}
}
}
return data;
}
export function populate_data_for_default_realm_settings_request(
$subsection_elem: JQuery,
): Record<string, string | boolean | number> {
const data: Record<string, string | boolean | number> = {};
const properties_elements = get_subsection_property_elements($subsection_elem);
for (const input_elem of properties_elements) {
const $input_elem = $(input_elem);
if (check_realm_default_settings_property_changed(input_elem)) {
const input_value = get_input_element_value(input_elem);
if (input_value !== undefined && input_value !== null) {
const property_name: string = extract_property_name($input_elem, true);
data[property_name] = input_value; data[property_name] = input_value;
} }
} }
@@ -1010,30 +1109,38 @@ function switching_to_private(properties_elements: HTMLElement[]): boolean {
return false; return false;
} }
export function save_discard_widget_status_handler( export function save_discard_realm_settings_widget_status_handler($subsection: JQuery): void {
$subsection.find(".subsection-failed-status p").hide();
$subsection.find(".save-button").show();
const properties_elements = get_subsection_property_elements($subsection);
const show_change_process_button = properties_elements.some((elem) =>
check_realm_settings_property_changed(elem),
);
const $save_btn_controls = $subsection.find(".subsection-header .save-button-controls");
const button_state = show_change_process_button ? "unsaved" : "discarded";
change_save_button_state($save_btn_controls, button_state);
}
export function save_discard_stream_settings_widget_status_handler(
$subsection: JQuery, $subsection: JQuery,
for_realm_default_settings: boolean, sub: StreamSubscription,
sub: StreamSubscription | undefined,
group: UserGroup | undefined,
): void { ): void {
$subsection.find(".subsection-failed-status p").hide(); $subsection.find(".subsection-failed-status p").hide();
$subsection.find(".save-button").show(); $subsection.find(".save-button").show();
const properties_elements = get_subsection_property_elements($subsection); const properties_elements = get_subsection_property_elements($subsection);
const show_change_process_button = properties_elements.some((elem) => const show_change_process_button = properties_elements.some((elem) =>
check_property_changed(elem, for_realm_default_settings, sub, group, undefined), check_stream_settings_property_changed(elem, sub),
); );
const $save_btn_controls = $subsection.find(".subsection-header .save-button-controls"); const $save_btn_controls = $subsection.find(".subsection-header .save-button-controls");
const button_state = show_change_process_button ? "unsaved" : "discarded"; const button_state = show_change_process_button ? "unsaved" : "discarded";
change_save_button_state($save_btn_controls, button_state); change_save_button_state($save_btn_controls, button_state);
// If this widget is for a stream, and the stream isn't currently private // If the stream isn't currently private but being changed to private,
// but being changed to private, and the user changing this setting isn't // and the user changing this setting isn't subscribed, we show a
// subscribed, we show a warning that they won't be able to access the // warning that they won't be able to access the stream after
// stream after making it private unless they subscribe. // making it private unless they subscribe.
if (!sub) {
return;
}
if ( if (
button_state === "unsaved" && button_state === "unsaved" &&
!sub.invite_only && !sub.invite_only &&
@@ -1061,6 +1168,36 @@ export function save_discard_widget_status_handler(
} }
} }
export function save_discard_group_widget_status_handler(
$subsection: JQuery,
group: UserGroup,
): void {
$subsection.find(".subsection-failed-status p").hide();
$subsection.find(".save-button").show();
const properties_elements = get_subsection_property_elements($subsection);
const show_change_process_button = properties_elements.some((elem) =>
check_group_property_changed(elem, group),
);
const $save_btn_controls = $subsection.find(".subsection-header .save-button-controls");
const button_state = show_change_process_button ? "unsaved" : "discarded";
change_save_button_state($save_btn_controls, button_state);
}
export function save_discard_default_realm_settings_widget_status_handler(
$subsection: JQuery,
): void {
$subsection.find(".subsection-failed-status p").hide();
$subsection.find(".save-button").show();
const properties_elements = get_subsection_property_elements($subsection);
const show_change_process_button = properties_elements.some((elem) =>
check_realm_default_settings_property_changed(elem),
);
const $save_btn_controls = $subsection.find(".subsection-header .save-button-controls");
const button_state = show_change_process_button ? "unsaved" : "discarded";
change_save_button_state($save_btn_controls, button_state);
}
function check_maximum_valid_value( function check_maximum_valid_value(
$custom_input_elem: JQuery<HTMLInputElement>, $custom_input_elem: JQuery<HTMLInputElement>,
property_name: string, property_name: string,

View File

@@ -308,10 +308,13 @@ function get_dropdown_value_for_message_retention_setting(setting_value) {
export function set_message_retention_setting_dropdown(sub) { export function set_message_retention_setting_dropdown(sub) {
let property_name = "realm_message_retention_days"; let property_name = "realm_message_retention_days";
let setting_value;
if (sub !== undefined) { if (sub !== undefined) {
property_name = "message_retention_days"; property_name = "message_retention_days";
setting_value = settings_components.get_stream_settings_property_value(property_name, sub);
} else {
setting_value = settings_components.get_realm_settings_property_value(property_name);
} }
const setting_value = settings_components.get_property_value(property_name, false, sub);
const dropdown_val = get_dropdown_value_for_message_retention_setting(setting_value); const dropdown_val = get_dropdown_value_for_message_retention_setting(setting_value);
const $dropdown_elem = $(`#id_${CSS.escape(property_name)}`); const $dropdown_elem = $(`#id_${CSS.escape(property_name)}`);
@@ -332,7 +335,9 @@ export function set_message_retention_setting_dropdown(sub) {
} }
function set_org_join_restrictions_dropdown() { function set_org_join_restrictions_dropdown() {
const value = settings_components.get_property_value("realm_org_join_restrictions"); const value = settings_components.get_realm_settings_property_value(
"realm_org_join_restrictions",
);
$("#id_realm_org_join_restrictions").val(value); $("#id_realm_org_join_restrictions").val(value);
settings_components.change_element_block_display_property( settings_components.change_element_block_display_property(
"allowed_domains_label", "allowed_domains_label",
@@ -465,29 +470,12 @@ function update_dependent_subsettings(property_name) {
} }
} }
export function discard_property_element_changes(elem, for_realm_default_settings, sub, group) { export function discard_realm_property_element_changes(elem) {
const $elem = $(elem); const $elem = $(elem);
const property_name = settings_components.extract_property_name( const property_name = settings_components.extract_property_name($elem);
$elem, const property_value = settings_components.get_realm_settings_property_value(property_name);
for_realm_default_settings,
);
const property_value = settings_components.get_property_value(
property_name,
for_realm_default_settings,
sub,
group,
);
switch (property_name) { switch (property_name) {
case "notification_sound":
audible_notifications.update_notification_sound_source(
$("audio#realm-default-notification-sound-audio"),
{
notification_sound: property_value,
},
);
settings_components.set_input_element_value($elem, property_value);
break;
case "realm_authentication_methods": case "realm_authentication_methods":
populate_auth_methods( populate_auth_methods(
settings_components.realm_authentication_methods_to_boolean_dict(), settings_components.realm_authentication_methods_to_boolean_dict(),
@@ -497,10 +485,8 @@ export function discard_property_element_changes(elem, for_realm_default_setting
case "realm_signup_announcements_stream_id": case "realm_signup_announcements_stream_id":
case "realm_zulip_update_announcements_stream_id": case "realm_zulip_update_announcements_stream_id":
case "realm_default_code_block_language": case "realm_default_code_block_language":
case "can_remove_subscribers_group":
case "realm_create_multiuse_invite_group": case "realm_create_multiuse_invite_group":
case "realm_can_access_all_users_group": case "realm_can_access_all_users_group":
case "can_mention_group":
settings_components.set_dropdown_list_widget_setting_value( settings_components.set_dropdown_list_widget_setting_value(
property_name, property_name,
property_value, property_value,
@@ -515,31 +501,6 @@ export function discard_property_element_changes(elem, for_realm_default_setting
get_language_name(property_value), get_language_name(property_value),
); );
break; break;
case "emojiset":
case "user_list_style":
// Because this widget has a radio button structure, it
// needs custom reset code.
$elem.find(`input[value='${CSS.escape(property_value)}']`).prop("checked", true);
break;
case "stream_privacy": {
$elem.find(`input[value='${CSS.escape(property_value)}']`).prop("checked", true);
// Hide stream privacy warning banner
const $stream_permissions_warning_banner = $(
"#stream_permission_settings .stream-permissions-warning-banner",
);
if (!$stream_permissions_warning_banner.is(":empty")) {
$stream_permissions_warning_banner.empty();
}
break;
}
case "email_notifications_batching_period_seconds":
case "email_notification_batching_period_edit_minutes":
settings_notifications.set_notification_batching_ui(
$("#realm-user-default-settings"),
realm_user_settings_defaults.email_notifications_batching_period_seconds,
);
break;
case "realm_org_type": case "realm_org_type":
settings_components.set_input_element_value($elem, property_value); settings_components.set_input_element_value($elem, property_value);
// Remove 'unspecified' option (value=0) from realm_org_type // Remove 'unspecified' option (value=0) from realm_org_type
@@ -566,9 +527,6 @@ export function discard_property_element_changes(elem, for_realm_default_setting
case "realm_message_retention_days": case "realm_message_retention_days":
set_message_retention_setting_dropdown(undefined); set_message_retention_setting_dropdown(undefined);
break; break;
case "message_retention_days":
set_message_retention_setting_dropdown(sub);
break;
case "realm_waiting_period_threshold": case "realm_waiting_period_threshold":
set_realm_waiting_period_setting(); set_realm_waiting_period_setting();
break; break;
@@ -579,7 +537,98 @@ export function discard_property_element_changes(elem, for_realm_default_setting
blueslip.error("Element refers to unknown property", {property_name}); blueslip.error("Element refers to unknown property", {property_name});
} }
} }
update_dependent_subsettings(property_name);
}
export function discard_stream_property_element_changes(elem, sub) {
const $elem = $(elem);
const property_name = settings_components.extract_property_name($elem);
const property_value = settings_components.get_stream_settings_property_value(
property_name,
sub,
);
switch (property_name) {
case "can_remove_subscribers_group":
settings_components.set_dropdown_list_widget_setting_value(
property_name,
property_value,
);
break;
case "stream_privacy": {
$elem.find(`input[value='${CSS.escape(property_value)}']`).prop("checked", true);
// Hide stream privacy warning banner
const $stream_permissions_warning_banner = $(
"#stream_permission_settings .stream-permissions-warning-banner",
);
if (!$stream_permissions_warning_banner.is(":empty")) {
$stream_permissions_warning_banner.empty();
}
break;
}
case "message_retention_days":
set_message_retention_setting_dropdown(sub);
break;
default:
if (property_value !== undefined) {
settings_components.set_input_element_value($elem, property_value);
} else {
blueslip.error("Element refers to unknown property", {property_name});
}
}
update_dependent_subsettings(property_name);
}
export function discard_group_property_element_changes(elem, group) {
const $elem = $(elem);
const property_name = settings_components.extract_property_name($elem);
const property_value = settings_components.get_group_property_value(property_name, group);
if (property_name === "can_mention_group") {
settings_components.set_dropdown_list_widget_setting_value(property_name, property_value);
} else if (property_value !== undefined) {
settings_components.set_input_element_value($elem, property_value);
} else {
blueslip.error("Element refers to unknown property", {property_name});
}
update_dependent_subsettings(property_name);
}
export function discard_realm_default_property_element_changes(elem) {
const $elem = $(elem);
const property_name = settings_components.extract_property_name($elem, true);
const property_value =
settings_components.get_realm_default_setting_property_value(property_name);
switch (property_name) {
case "notification_sound":
audible_notifications.update_notification_sound_source(
$("audio#realm-default-notification-sound-audio"),
{
notification_sound: property_value,
},
);
settings_components.set_input_element_value($elem, property_value);
break;
case "emojiset":
case "user_list_style":
// Because this widget has a radio button structure, it
// needs custom reset code.
$elem.find(`input[value='${CSS.escape(property_value)}']`).prop("checked", true);
break;
case "email_notifications_batching_period_seconds":
case "email_notification_batching_period_edit_minutes":
settings_notifications.set_notification_batching_ui(
$("#realm-user-default-settings"),
realm_user_settings_defaults.email_notifications_batching_period_seconds,
);
break;
default:
if (property_value !== undefined) {
settings_components.set_input_element_value($elem, property_value);
} else {
blueslip.error("Element refers to unknown property", {property_name});
}
}
update_dependent_subsettings(property_name); update_dependent_subsettings(property_name);
} }
@@ -622,7 +671,7 @@ export function sync_realm_settings(property) {
} }
const $element = $(`#id_realm_${CSS.escape(property)}`); const $element = $(`#id_realm_${CSS.escape(property)}`);
if ($element.length) { if ($element.length) {
discard_property_element_changes($element); discard_realm_property_element_changes($element);
} }
} }
@@ -679,7 +728,9 @@ export function init_dropdown_widgets() {
event.preventDefault(); event.preventDefault();
event.stopPropagation(); event.stopPropagation();
settings_components.new_stream_announcements_stream_widget.render(); settings_components.new_stream_announcements_stream_widget.render();
settings_components.save_discard_widget_status_handler($("#org-notifications")); settings_components.save_discard_realm_settings_widget_status_handler(
$("#org-notifications"),
);
}, },
tippy_props: { tippy_props: {
placement: "bottom-start", placement: "bottom-start",
@@ -702,7 +753,9 @@ export function init_dropdown_widgets() {
event.preventDefault(); event.preventDefault();
event.stopPropagation(); event.stopPropagation();
settings_components.signup_announcements_stream_widget.render(); settings_components.signup_announcements_stream_widget.render();
settings_components.save_discard_widget_status_handler($("#org-notifications")); settings_components.save_discard_realm_settings_widget_status_handler(
$("#org-notifications"),
);
}, },
tippy_props: { tippy_props: {
placement: "bottom-start", placement: "bottom-start",
@@ -723,7 +776,9 @@ export function init_dropdown_widgets() {
event.preventDefault(); event.preventDefault();
event.stopPropagation(); event.stopPropagation();
settings_components.zulip_update_announcements_stream_widget.render(); settings_components.zulip_update_announcements_stream_widget.render();
settings_components.save_discard_widget_status_handler($("#org-notifications")); settings_components.save_discard_realm_settings_widget_status_handler(
$("#org-notifications"),
);
}, },
tippy_props: { tippy_props: {
placement: "bottom-start", placement: "bottom-start",
@@ -765,7 +820,9 @@ export function init_dropdown_widgets() {
event.preventDefault(); event.preventDefault();
event.stopPropagation(); event.stopPropagation();
settings_components.default_code_language_widget.render(); settings_components.default_code_language_widget.render();
settings_components.save_discard_widget_status_handler($("#org-other-settings")); settings_components.save_discard_realm_settings_widget_status_handler(
$("#org-other-settings"),
);
}, },
}); });
settings_components.set_default_code_language_widget(default_code_language_widget); settings_components.set_default_code_language_widget(default_code_language_widget);
@@ -784,7 +841,9 @@ export function init_dropdown_widgets() {
event.preventDefault(); event.preventDefault();
event.stopPropagation(); event.stopPropagation();
settings_components.create_multiuse_invite_group_widget.render(); settings_components.create_multiuse_invite_group_widget.render();
settings_components.save_discard_widget_status_handler($("#org-join-settings")); settings_components.save_discard_realm_settings_widget_status_handler(
$("#org-join-settings"),
);
}, },
tippy_props: { tippy_props: {
placement: "bottom-start", placement: "bottom-start",
@@ -813,7 +872,9 @@ export function init_dropdown_widgets() {
event.preventDefault(); event.preventDefault();
event.stopPropagation(); event.stopPropagation();
settings_components.can_access_all_users_group_widget.render(); settings_components.can_access_all_users_group_widget.render();
settings_components.save_discard_widget_status_handler($("#org-guest-settings")); settings_components.save_discard_realm_settings_widget_status_handler(
$("#org-guest-settings"),
);
}, },
tippy_props: { tippy_props: {
placement: "bottom-start", placement: "bottom-start",
@@ -860,10 +921,14 @@ export function register_save_discard_widget_handlers(
} }
const $subsection = $(e.target).closest(".settings-subsection-parent"); const $subsection = $(e.target).closest(".settings-subsection-parent");
settings_components.save_discard_widget_status_handler( if (for_realm_default_settings) {
$subsection, settings_components.save_discard_default_realm_settings_widget_status_handler(
for_realm_default_settings, $subsection,
); );
} else {
settings_components.save_discard_realm_settings_widget_status_handler($subsection);
}
return undefined; return undefined;
}); });
@@ -872,7 +937,11 @@ export function register_save_discard_widget_handlers(
e.stopPropagation(); e.stopPropagation();
const $subsection = $(e.target).closest(".settings-subsection-parent"); const $subsection = $(e.target).closest(".settings-subsection-parent");
for (const elem of settings_components.get_subsection_property_elements($subsection)) { for (const elem of settings_components.get_subsection_property_elements($subsection)) {
discard_property_element_changes(elem, for_realm_default_settings); if (for_realm_default_settings) {
discard_realm_default_property_element_changes(elem);
} else {
discard_realm_property_element_changes(elem);
}
} }
const $save_btn_controls = $(e.target).closest(".save-button-controls"); const $save_btn_controls = $(e.target).closest(".save-button-controls");
settings_components.change_save_button_state($save_btn_controls, "discarded"); settings_components.change_save_button_state($save_btn_controls, "discarded");
@@ -883,11 +952,15 @@ export function register_save_discard_widget_handlers(
e.stopPropagation(); e.stopPropagation();
const $save_button = $(e.currentTarget); const $save_button = $(e.currentTarget);
const $subsection_elem = $save_button.closest(".settings-subsection-parent"); const $subsection_elem = $save_button.closest(".settings-subsection-parent");
let data;
const data = settings_components.populate_data_for_request( if (!for_realm_default_settings) {
$subsection_elem, data = settings_components.populate_data_for_realm_settings_request($subsection_elem);
for_realm_default_settings, } else {
); data =
settings_components.populate_data_for_default_realm_settings_request(
$subsection_elem,
);
}
save_organization_settings(data, $save_button, patch_url); save_organization_settings(data, $save_button, patch_url);
}); });
} }

View File

@@ -76,7 +76,9 @@ function org_notification_default_language_modal_post_render() {
); );
$language_element.text(new_language); $language_element.text(new_language);
$language_element.attr("data-language-code", setting_value); $language_element.attr("data-language-code", setting_value);
settings_components.save_discard_widget_status_handler($("#org-notifications")); settings_components.save_discard_realm_settings_widget_status_handler(
$("#org-notifications"),
);
}); });
} }

View File

@@ -379,11 +379,8 @@ function disable_submit_btn_if_no_property_changed(
$profile_field_form: JQuery, $profile_field_form: JQuery,
field: CustomProfileField, field: CustomProfileField,
): void { ): void {
const data = settings_components.populate_data_for_request( const data = settings_components.populate_data_for_custom_profile_field_request(
$profile_field_form, $profile_field_form,
false,
undefined,
undefined,
field, field,
); );
let save_changes_button_disabled = false; let save_changes_button_disabled = false;
@@ -520,11 +517,8 @@ function open_edit_form_modal(this: HTMLElement): void {
function submit_form(): void { function submit_form(): void {
const $profile_field_form = $("#edit-custom-profile-field-form-" + field_id); const $profile_field_form = $("#edit-custom-profile-field-form-" + field_id);
const data = settings_components.populate_data_for_request( const data = settings_components.populate_data_for_custom_profile_field_request(
$profile_field_form, $profile_field_form,
false,
undefined,
undefined,
field, field,
); );

View File

@@ -211,9 +211,8 @@ function setup_dropdown(sub, slim_sub) {
event.preventDefault(); event.preventDefault();
event.stopPropagation(); event.stopPropagation();
can_remove_subscribers_group_widget.render(); can_remove_subscribers_group_widget.render();
settings_components.save_discard_widget_status_handler( settings_components.save_discard_stream_settings_widget_status_handler(
$("#stream_permission_settings"), $("#stream_permission_settings"),
false,
slim_sub, slim_sub,
); );
}, },
@@ -683,7 +682,7 @@ export function initialize() {
const stream_id = get_stream_id(e.target); const stream_id = get_stream_id(e.target);
const sub = sub_store.get(stream_id); const sub = sub_store.get(stream_id);
const $subsection = $(e.target).closest(".settings-subsection-parent"); const $subsection = $(e.target).closest(".settings-subsection-parent");
settings_components.save_discard_widget_status_handler($subsection, false, sub); settings_components.save_discard_stream_settings_widget_status_handler($subsection, sub);
if (sub) { if (sub) {
stream_ui_updates.update_default_stream_and_stream_privacy_state($subsection); stream_ui_updates.update_default_stream_and_stream_privacy_state($subsection);
} }
@@ -703,9 +702,8 @@ export function initialize() {
$save_button.closest(".subscription_settings.show").attr("data-stream-id"), $save_button.closest(".subscription_settings.show").attr("data-stream-id"),
); );
const sub = sub_store.get(stream_id); const sub = sub_store.get(stream_id);
const data = settings_components.populate_data_for_request( const data = settings_components.populate_data_for_stream_settings_request(
$subsection_elem, $subsection_elem,
false,
sub, sub,
); );
@@ -744,7 +742,7 @@ export function initialize() {
const $subsection = $(e.target).closest(".settings-subsection-parent"); const $subsection = $(e.target).closest(".settings-subsection-parent");
for (const elem of settings_components.get_subsection_property_elements($subsection)) { for (const elem of settings_components.get_subsection_property_elements($subsection)) {
settings_org.discard_property_element_changes(elem, false, sub); settings_org.discard_stream_property_element_changes(elem, sub);
} }
stream_ui_updates.update_default_stream_and_stream_privacy_state($subsection); stream_ui_updates.update_default_stream_and_stream_privacy_state($subsection);
const $save_btn_controls = $(e.target).closest(".save-button-controls"); const $save_btn_controls = $(e.target).closest(".save-button-controls");

View File

@@ -382,7 +382,7 @@ export function update_setting_element(sub, setting_name) {
} }
const $elem = $(`#id_${CSS.escape(setting_name)}`); const $elem = $(`#id_${CSS.escape(setting_name)}`);
settings_org.discard_property_element_changes($elem, false, sub); settings_org.discard_stream_property_element_changes($elem, sub);
} }
export function enable_or_disable_add_subscribers_elements( export function enable_or_disable_add_subscribers_elements(

View File

@@ -29,10 +29,8 @@ export function setup_permissions_dropdown(group: UserGroup, for_group_creation:
event.stopPropagation(); event.stopPropagation();
can_mention_group_widget.render(); can_mention_group_widget.render();
if (!for_group_creation) { if (!for_group_creation) {
settings_components.save_discard_widget_status_handler( settings_components.save_discard_group_widget_status_handler(
$("#group_permission_settings"), $("#group_permission_settings"),
false,
undefined,
group, group,
); );
} }

View File

@@ -251,12 +251,7 @@ export function update_settings_pane(group) {
$edit_container.find(".group-name").text(group.name); $edit_container.find(".group-name").text(group.name);
$edit_container.find(".group-description").text(group.description); $edit_container.find(".group-description").text(group.description);
settings_org.discard_property_element_changes( settings_org.discard_group_property_element_changes($("#id_can_mention_group"), group);
$("#id_can_mention_group"),
false,
undefined,
group,
);
} }
function update_toggler_for_group_setting() { function update_toggler_for_group_setting() {
@@ -928,10 +923,8 @@ export function initialize() {
const group_id = $save_button.closest(".user_group_settings_wrapper").data("group-id"); const group_id = $save_button.closest(".user_group_settings_wrapper").data("group-id");
const group = user_groups.get_user_group_from_id(group_id); const group = user_groups.get_user_group_from_id(group_id);
const data = settings_components.populate_data_for_request( const data = settings_components.populate_data_for_group_request(
$subsection_elem, $subsection_elem,
false,
undefined,
group, group,
); );
@@ -952,7 +945,7 @@ export function initialize() {
const $subsection = $(e.target).closest(".settings-subsection-parent"); const $subsection = $(e.target).closest(".settings-subsection-parent");
for (const elem of settings_components.get_subsection_property_elements($subsection)) { for (const elem of settings_components.get_subsection_property_elements($subsection)) {
settings_org.discard_property_element_changes(elem, false, undefined, group); settings_org.discard_group_property_element_changes(elem, group);
} }
const $save_btn_controls = $(e.target).closest(".save-button-controls"); const $save_btn_controls = $(e.target).closest(".save-button-controls");
settings_components.change_save_button_state($save_btn_controls, "discarded"); settings_components.change_save_button_state($save_btn_controls, "discarded");