FIX: Fix broken translation in tags input field objects setting editor (#26340)
Why this change? When a property of `type: tags` is required, we should be displaying the "at least 1 tag is required" validation error message when there are no tags selected in the `TagChooser` compoment. However, we were passing `this.min` as the `count` attribute when generating the translation string which is incorrect as `this.min` is not always set.
This commit is contained in:
parent
83ca1fd134
commit
8a6e43a3d4
|
@ -36,8 +36,8 @@ export default class SchemaThemeSettingTypeTags extends Component {
|
||||||
(this.min && this.value.length < this.min) ||
|
(this.min && this.value.length < this.min) ||
|
||||||
(this.required && (!this.value || this.value.length === 0))
|
(this.required && (!this.value || this.value.length === 0))
|
||||||
) {
|
) {
|
||||||
return I18n.t("admin.customize.theme.schema.fields.tags.at_least_tag", {
|
return I18n.t("admin.customize.theme.schema.fields.tags.at_least", {
|
||||||
count: this.min,
|
count: this.min || 1,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -736,6 +736,10 @@ module(
|
||||||
required_tags: {
|
required_tags: {
|
||||||
type: "tags",
|
type: "tags",
|
||||||
required: true,
|
required: true,
|
||||||
|
},
|
||||||
|
required_tags_with_validations: {
|
||||||
|
type: "tags",
|
||||||
|
required: true,
|
||||||
validations: {
|
validations: {
|
||||||
min: 2,
|
min: 2,
|
||||||
max: 3,
|
max: 3,
|
||||||
|
@ -745,7 +749,8 @@ module(
|
||||||
},
|
},
|
||||||
value: [
|
value: [
|
||||||
{
|
{
|
||||||
required_tags: ["gazelle", "cat"],
|
required_tags: ["gazelle"],
|
||||||
|
required_tags_with_validations: ["gazelle", "cat"],
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
});
|
});
|
||||||
|
@ -756,8 +761,8 @@ module(
|
||||||
|
|
||||||
const inputFields = new InputFieldsFromDOM();
|
const inputFields = new InputFieldsFromDOM();
|
||||||
|
|
||||||
const tagSelector = selectKit(
|
let tagSelector = selectKit(
|
||||||
`${inputFields.fields.required_tags.selector} .select-kit`
|
`${inputFields.fields.required_tags_with_validations.selector} .select-kit`
|
||||||
);
|
);
|
||||||
|
|
||||||
assert.strictEqual(tagSelector.header().value(), "gazelle,cat");
|
assert.strictEqual(tagSelector.header().value(), "gazelle,cat");
|
||||||
|
@ -778,8 +783,10 @@ module(
|
||||||
|
|
||||||
inputFields.refresh();
|
inputFields.refresh();
|
||||||
|
|
||||||
assert.dom(inputFields.fields.required_tags.errorElement).hasText(
|
assert
|
||||||
I18n.t("admin.customize.theme.schema.fields.tags.at_least_tag", {
|
.dom(inputFields.fields.required_tags_with_validations.errorElement)
|
||||||
|
.hasText(
|
||||||
|
I18n.t("admin.customize.theme.schema.fields.tags.at_least", {
|
||||||
count: 2,
|
count: 2,
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
|
@ -791,11 +798,29 @@ module(
|
||||||
|
|
||||||
inputFields.refresh();
|
inputFields.refresh();
|
||||||
|
|
||||||
assert.dom(inputFields.fields.required_tags.errorElement).hasText(
|
assert
|
||||||
I18n.t("admin.customize.theme.schema.fields.tags.at_least_tag", {
|
.dom(inputFields.fields.required_tags_with_validations.errorElement)
|
||||||
|
.hasText(
|
||||||
|
I18n.t("admin.customize.theme.schema.fields.tags.at_least", {
|
||||||
count: 2,
|
count: 2,
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
|
|
||||||
|
tagSelector = selectKit(
|
||||||
|
`${inputFields.fields.required_tags.selector} .select-kit`
|
||||||
|
);
|
||||||
|
|
||||||
|
await tagSelector.expand();
|
||||||
|
await tagSelector.deselectItemByName("gazelle");
|
||||||
|
await tagSelector.collapse();
|
||||||
|
|
||||||
|
inputFields.refresh();
|
||||||
|
|
||||||
|
assert.dom(inputFields.fields.required_tags.errorElement).hasText(
|
||||||
|
I18n.t("admin.customize.theme.schema.fields.tags.at_least", {
|
||||||
|
count: 1,
|
||||||
|
})
|
||||||
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
test("input fields of type group", async function (assert) {
|
test("input fields of type group", async function (assert) {
|
||||||
|
|
|
@ -5653,7 +5653,7 @@ en:
|
||||||
fields:
|
fields:
|
||||||
required: "*required"
|
required: "*required"
|
||||||
tags:
|
tags:
|
||||||
at_least_tag:
|
at_least:
|
||||||
one: "at least %{count} tag is required"
|
one: "at least %{count} tag is required"
|
||||||
other: "at least %{count} tags are required"
|
other: "at least %{count} tags are required"
|
||||||
string:
|
string:
|
||||||
|
|
Loading…
Reference in New Issue