mirror of
https://github.com/flarum/framework.git
synced 2025-01-20 23:42:58 +08:00
Use ItemList for DiscussionPage content (#3004)
* Use ItemList for DiscussionPage content * Don't import Mithril
This commit is contained in:
parent
ca9aa2d76f
commit
8726634459
|
@ -69,36 +69,88 @@ export default class DiscussionPage extends Page {
|
|||
}
|
||||
|
||||
view() {
|
||||
const discussion = this.discussion;
|
||||
|
||||
return (
|
||||
<div className="DiscussionPage">
|
||||
<DiscussionListPane state={app.discussions} />
|
||||
<div className="DiscussionPage-discussion">
|
||||
{discussion ? (
|
||||
[
|
||||
DiscussionHero.component({ discussion }),
|
||||
<div className="container">
|
||||
<nav className="DiscussionPage-nav">
|
||||
<ul>{listItems(this.sidebarItems().toArray())}</ul>
|
||||
</nav>
|
||||
<div className="DiscussionPage-stream">
|
||||
{PostStream.component({
|
||||
discussion,
|
||||
stream: this.stream,
|
||||
onPositionChange: this.positionChanged.bind(this),
|
||||
})}
|
||||
</div>
|
||||
</div>,
|
||||
]
|
||||
) : (
|
||||
<LoadingIndicator />
|
||||
)}
|
||||
</div>
|
||||
<div className="DiscussionPage-discussion">{this.discussion ? this.pageContent().toArray() : this.loadingItems().toArray()}</div>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* List of components shown while the discussion is loading.
|
||||
*
|
||||
* @returns {ItemList}
|
||||
*/
|
||||
loadingItems() {
|
||||
const items = new ItemList();
|
||||
|
||||
items.add('spinner', <LoadingIndicator />, 100);
|
||||
|
||||
return items;
|
||||
}
|
||||
|
||||
/**
|
||||
* Function that renders the `sidebarItems` ItemList.
|
||||
*
|
||||
* @returns {import('mithril').Children}
|
||||
*/
|
||||
sidebar() {
|
||||
return (
|
||||
<nav className="DiscussionPage-nav">
|
||||
<ul>{listItems(this.sidebarItems().toArray())}</ul>
|
||||
</nav>
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Renders the discussion's hero.
|
||||
*
|
||||
* @returns {import('mithril').Children}
|
||||
*/
|
||||
hero() {
|
||||
return <DiscussionHero discussion={this.discussion} />;
|
||||
}
|
||||
|
||||
/**
|
||||
* List of items rendered as the main page content.
|
||||
*
|
||||
* @returns {ItemList}
|
||||
*/
|
||||
pageContent() {
|
||||
const items = new ItemList();
|
||||
|
||||
items.add('hero', this.hero(), 100);
|
||||
items.add('main', <div className="container">{this.mainContent().toArray()}</div>, 10);
|
||||
|
||||
return items;
|
||||
}
|
||||
|
||||
/**
|
||||
* List of items rendered inside the main page content container.
|
||||
*
|
||||
* @returns {ItemList}
|
||||
*/
|
||||
mainContent() {
|
||||
const items = new ItemList();
|
||||
|
||||
items.add('sidebar', this.sidebar(), 100);
|
||||
|
||||
items.add(
|
||||
'poststream',
|
||||
<div className="DiscussionPage-stream">
|
||||
{PostStream.component({
|
||||
discussion,
|
||||
stream: this.stream,
|
||||
onPositionChange: this.positionChanged.bind(this),
|
||||
})}
|
||||
</div>,
|
||||
10
|
||||
);
|
||||
|
||||
return items;
|
||||
}
|
||||
|
||||
/**
|
||||
* Load the discussion from the API or use the preloaded one.
|
||||
*/
|
||||
|
|
Loading…
Reference in New Issue
Block a user