DEV: Don't ask admin to re-confirm 'for all users' when requirement didn't change (#29307)

When adding or updating a custom user field to apply to all users (retroactively) we want to alert the admin that this will force all existing users to fill up the field before they are able to access the forum again.

However, we currently show this prompt when making changes only to other attributes on the custom field, i.e. the requirement hasn't changed.

This commit fixes that.
This commit is contained in:
Ted Johansson 2024-10-21 14:37:46 +08:00 committed by GitHub
parent a017b60879
commit 6f55457652
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 25 additions and 1 deletions

View File

@ -19,6 +19,8 @@ export default class AdminUserFieldItem extends Component {
@tracked @tracked
editableDisabled = this.args.userField.requirement === "for_all_users"; editableDisabled = this.args.userField.requirement === "for_all_users";
originalRequirement = this.args.userField.requirement;
get fieldName() { get fieldName() {
return UserField.fieldTypeById(this.fieldType)?.name; return UserField.fieldTypeById(this.fieldType)?.name;
} }
@ -85,7 +87,10 @@ export default class AdminUserFieldItem extends Component {
async save(data) { async save(data) {
let confirm = true; let confirm = true;
if (data.requirement === "for_all_users") { if (
data.requirement === "for_all_users" &&
this.originalRequirement !== "for_all_users"
) {
confirm = await this._confirmChanges(); confirm = await this._confirmChanges();
} }
@ -100,6 +105,7 @@ export default class AdminUserFieldItem extends Component {
return; return;
} }
this.originalRequirement = data.requirement;
this.isEditing = false; this.isEditing = false;
}) })
.catch(popupAjaxError); .catch(popupAjaxError);

View File

@ -59,4 +59,22 @@ describe "Admin User Fields", type: :system, js: true do
expect(page).to have_text(I18n.t("admin_js.admin.user_fields.requirement.confirmation")) expect(page).to have_text(I18n.t("admin_js.admin.user_fields.requirement.confirmation"))
end end
context "when editing an existing user field" do
fab!(:user_field) { Fabricate(:user_field, requirement: "for_all_users") }
it "does not require confirmation if the field already applies to all users" do
user_fields_page.visit
page.find(".user-field .edit").click
form = page.find(".user-field")
form.find(".user-field-name").fill_in(with: "Favourite Transformer")
form.find(".btn-primary").click
expect(page).to have_no_text(I18n.t("admin_js.admin.user_fields.requirement.confirmation"))
end
end
end end