UX: Switch no categories/tags configured text in sidebar to a link (#18787)

Internal Ref: /t/73500
This commit is contained in:
Alan Guo Xiang Tan 2022-10-31 06:42:55 +08:00 committed by GitHub
parent fa9e708cb7
commit cfefdf0832
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 41 additions and 38 deletions

View File

@ -25,9 +25,14 @@
</Sidebar::SectionLink> </Sidebar::SectionLink>
{{/each}} {{/each}}
{{else}} {{else}}
<Sidebar::SectionMessage> <Sidebar::SectionLink
{{html-safe this.noCategoriesText}} @linkName="configure-categories"
</Sidebar::SectionMessage> @route="preferences.sidebar"
@prefixType="icon"
@prefixValue="pencil-alt"
@model={{this.currentUser}}
@content={{i18n "sidebar.sections.categories.links.add_categories.content"}}
@title={{i18n "sidebar.sections.categories.links.add_categories.title"}} />
{{/if}} {{/if}}
<Sidebar::Common::AllCategoriesSectionLink /> <Sidebar::Common::AllCategoriesSectionLink />

View File

@ -1,5 +1,3 @@
import I18n from "I18n";
import { inject as service } from "@ember/service"; import { inject as service } from "@ember/service";
import { action } from "@ember/object"; import { action } from "@ember/object";
@ -32,16 +30,6 @@ export default class SidebarUserCategoriesSection extends SidebarCommonCategorie
}); });
} }
get noCategoriesText() {
const url = `/u/${this.currentUser.username}/preferences/sidebar`;
return `${I18n.t(
"sidebar.sections.categories.none"
)} <a href="${url}">${I18n.t(
"sidebar.sections.categories.click_to_get_started"
)}</a>`;
}
/** /**
* If a site has no default sidebar categories configured, show categories section if the user has categories configured. * If a site has no default sidebar categories configured, show categories section if the user has categories configured.
* Otherwise, hide the categories section from the sidebar for the user. * Otherwise, hide the categories section from the sidebar for the user.

View File

@ -21,9 +21,14 @@
</Sidebar::SectionLink> </Sidebar::SectionLink>
{{/each}} {{/each}}
{{else}} {{else}}
<Sidebar::SectionMessage> <Sidebar::SectionLink
{{html-safe this.noTagsText}} @linkName="configure-tags"
</Sidebar::SectionMessage> @route="preferences.sidebar"
@prefixType="icon"
@prefixValue="pencil-alt"
@model={{this.currentUser}}
@content={{i18n "sidebar.sections.tags.links.add_tags.content"}}
@title={{i18n "sidebar.sections.tags.links.add_tags.title"}} />
{{/if}} {{/if}}
<Sidebar::Common::AllTagsSectionLink /> <Sidebar::Common::AllTagsSectionLink />

View File

@ -1,5 +1,3 @@
import I18n from "I18n";
import { cached } from "@glimmer/tracking"; import { cached } from "@glimmer/tracking";
import Component from "@glimmer/component"; import Component from "@glimmer/component";
import { inject as service } from "@ember/service"; import { inject as service } from "@ember/service";
@ -57,14 +55,6 @@ export default class SidebarUserTagsSection extends Component {
return links; return links;
} }
get noTagsText() {
const url = `/u/${this.currentUser.username}/preferences/sidebar`;
return `${I18n.t("sidebar.sections.tags.none")} <a href="${url}">${I18n.t(
"sidebar.sections.tags.click_to_get_started"
)}</a>`;
}
/** /**
* If a site has no default sidebar tags configured, show tags section if the user has personal sidebar tags configured. * If a site has no default sidebar tags configured, show tags section if the user has personal sidebar tags configured.
* Otherwise, hide the tags section from the sidebar for the user. * Otherwise, hide the tags section from the sidebar for the user.

View File

@ -159,11 +159,15 @@ acceptance("Sidebar - Logged on user - Categories Section", function (needs) {
); );
assert.ok( assert.ok(
exists(".sidebar-section-message"), exists(
"the no categories message is displayed" ".sidebar-section-categories .sidebar-section-link-configure-categories"
),
"section link to add categories to sidebar is displayed"
); );
await click(".sidebar-section-message a"); await click(
".sidebar-section-categories .sidebar-section-link-configure-categories"
);
assert.strictEqual( assert.strictEqual(
currentURL(), currentURL(),

View File

@ -139,14 +139,17 @@ acceptance("Sidebar - Logged on user - Tags section", function (needs) {
assert.ok(exists(".sidebar-section-tags"), "tags section is shown"); assert.ok(exists(".sidebar-section-tags"), "tags section is shown");
assert.ok(
exists(".sidebar-section-tags .sidebar-section-link-configure-tags"),
"section link to add tags to sidebar is displayed"
);
await click(".sidebar-section-tags .sidebar-section-link-configure-tags");
assert.strictEqual( assert.strictEqual(
query( currentURL(),
".sidebar-section-tags .sidebar-section-message" "/u/eviltrout/preferences/sidebar",
).textContent.trim(), "it should transition to user preferences sidebar page"
`${I18n.t("sidebar.sections.tags.none")} ${I18n.t(
"sidebar.sections.tags.click_to_get_started"
)}`,
"the no tags message is displayed"
); );
}); });

View File

@ -4196,12 +4196,20 @@ en:
unread_with_count: "Unread (%{count})" unread_with_count: "Unread (%{count})"
archive: "Archive" archive: "Archive"
tags: tags:
links:
add_tags:
content: "Add tags"
title: "You have not added any tags. Click to get started."
none: "You have not added any tags." none: "You have not added any tags."
click_to_get_started: "Click here to get started." click_to_get_started: "Click here to get started."
header_link_text: "Tags" header_link_text: "Tags"
header_action_title: "edit your sidebar tags" header_action_title: "edit your sidebar tags"
configure_defaults: "Configure defaults" configure_defaults: "Configure defaults"
categories: categories:
links:
add_categories:
content: "Add categories"
title: "You have not added any categories. Click to get started."
none: "You have not added any categories." none: "You have not added any categories."
click_to_get_started: "Click here to get started." click_to_get_started: "Click here to get started."
header_link_text: "Categories" header_link_text: "Categories"