DEV: First pass at messages section experimental sidebar (#17084)

This commit is contained in:
Alan Guo Xiang Tan 2022-06-14 15:56:20 +08:00 committed by GitHub
parent e7e23e8d9c
commit 4a240f6c90
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 84 additions and 1 deletions

View File

@ -0,0 +1,17 @@
import { action } from "@ember/object";
import GlimmerComponent from "discourse/components/glimmer";
import Composer from "discourse/models/composer";
import { getOwner } from "discourse-common/lib/get-owner";
export default class SidebarMessagesSection extends GlimmerComponent {
@action
composePersonalMessage() {
const composerArgs = {
action: Composer.PRIVATE_MESSAGE,
draftKey: Composer.NEW_TOPIC_KEY,
};
getOwner(this).lookup("controller:composer").open(composerArgs);
}
}

View File

@ -7,6 +7,8 @@
{{#if this.siteSettings.tagging_enabled}} {{#if this.siteSettings.tagging_enabled}}
<Sidebar::TagsSection /> <Sidebar::TagsSection />
{{/if}} {{/if}}
<Sidebar::MessagesSection />
</div> </div>
</div> </div>
{{/if}} {{/if}}

View File

@ -0,0 +1,10 @@
<Sidebar::Section
@sectionName="messages"
@headerRoute="userPrivateMessages.index"
@headerModel={{this.currentUser}}
@headerAction={{this.composePersonalMessage}}
@headerActionIcon="plus"
@headerLinkText={{i18n "sidebar.sections.messages.header_link_text"}}
@headerLinkTitle={{i18n "sidebar.sections.messages.header_link_title"}} >
</Sidebar::Section>

View File

@ -4,7 +4,13 @@
{{d-icon this.headerCaretIcon}} {{d-icon this.headerCaretIcon}}
</button> </button>
<LinkTo @route={{@headerRoute}} @query={{@headerQuery}} @class="sidebar-section-header-link" title={{@headerLinkTitle}}> <LinkTo
@route={{@headerRoute}}
@query={{@headerQuery}}
@models={{if @headerModel (array @headerModel) (if @headerModels @headerModels (array))}}
@class="sidebar-section-header-link"
title={{@headerLinkTitle}}>
{{@headerLinkText}} {{@headerLinkText}}
</LinkTo> </LinkTo>

View File

@ -0,0 +1,44 @@
import { click, currentURL, visit } from "@ember/test-helpers";
import {
acceptance,
conditionalTest,
exists,
} from "discourse/tests/helpers/qunit-helpers";
import { isLegacyEmber } from "discourse-common/config/environment";
acceptance("Sidebar - Messages Section", function (needs) {
needs.user({
experimental_sidebar_enabled: true,
});
conditionalTest(
"clicking on section header button",
!isLegacyEmber(),
async function (assert) {
await visit("/");
await click(".sidebar-section-messages .sidebar-section-header-button");
assert.ok(
exists("#reply-control.private-message"),
"it opens the composer"
);
}
);
conditionalTest(
"clicking on section header link",
!isLegacyEmber(),
async function (assert) {
await visit("/");
await click(".sidebar-section-messages .sidebar-section-header-link");
assert.strictEqual(
currentURL(),
`/u/eviltrout/messages`,
"it should transistion to the user's messages"
);
}
);
});

View File

@ -4041,6 +4041,10 @@ en:
unread_count: "%{count} unread" unread_count: "%{count} unread"
new_count: "%{count} new" new_count: "%{count} new"
sections: sections:
messages:
header_link_title: "personal messages"
header_link_text: "Messages"
header_action_title: "create a personal message"
tags: tags:
no_tracked_tags: "You are not tracking any tags." no_tracked_tags: "You are not tracking any tags."
header_link_title: "all tags" header_link_title: "all tags"