render() {
return (
- <nav className="container-lg navbar navbar-expand-md navbar-light navbar-bg p-3">
+ <nav
+ id="footer"
+ className="container-lg navbar navbar-expand-md navbar-light navbar-bg p-3"
+ >
<div className="navbar-collapse">
<ul className="navbar-nav ml-auto">
{this.props.site?.version !== VERSION && (
const siteView = this.props.siteRes?.site_view;
const person = UserService.Instance.myUserInfo?.local_user_view.person;
return (
- <nav className="navbar navbar-expand-md navbar-light shadow-sm p-0 px-3 container-lg">
+ <nav
+ className="navbar navbar-expand-md navbar-light shadow-sm p-0 px-3 container-lg"
+ id="navbar"
+ >
<NavLink
+ id="navTitle"
to="/"
title={siteView?.site.description ?? siteView?.site.name}
className="d-flex align-items-center navbar-brand mr-md-3"
</NavLink>
{person && (
<ul className="navbar-nav d-flex flex-row ml-auto d-md-none">
- <li className="nav-item">
+ <li className="nav-item nav-item-icon">
<NavLink
to="/inbox"
- className="p-1 nav-link border-0"
+ className="p-1 nav-link border-0 nav-messages"
title={i18n.t("unread_messages", {
count: Number(this.state.unreadApplicationCountRes.state),
formattedCount: numToSI(this.unreadInboxCount),
</NavLink>
</li>
{this.moderatesSomething && (
- <li className="nav-item">
+ <li className="nav-item nav-item-icon">
<NavLink
to="/reports"
className="p-1 nav-link border-0"
</li>
)}
{amAdmin() && (
- <li className="nav-item">
+ <li className="nav-item nav-item-icon">
<NavLink
to="/registration_applications"
className="p-1 nav-link border-0"
id="navbarDropdown"
ref={this.mobileMenuRef}
>
- <ul className="mr-auto navbar-nav">
+ <ul id="navbarLinks" className="mr-auto navbar-nav">
<li className="nav-item">
<NavLink
to="/communities"
</a>
</li>
</ul>
- <ul className="navbar-nav">
- <li className="nav-item">
+ <ul id="navbarIcons" className="navbar-nav">
+ <li className="nav-item nav-item-search">
<NavLink
to="/search"
className="nav-link"
</NavLink>
</li>
{amAdmin() && (
- <li className="nav-item">
+ <li className="nav-item nav-item-admin">
<NavLink
to="/admin"
className="nav-link"
)}
{person ? (
<>
- <li className="nav-item">
+ <li className="nav-item nav-item-messages">
<NavLink
className="nav-link"
to="/inbox"
</NavLink>
</li>
{this.moderatesSomething && (
- <li className="nav-item">
+ <li className="nav-item nav-item-moderation">
<NavLink
className="nav-link"
to="/reports"
</li>
)}
{amAdmin() && (
- <li className="nav-item">
+ <li className="nav-item nav-item-applications">
<NavLink
to="/registration_applications"
className="nav-link"
</li>
)}
{person && (
- <div className="dropdown">
+ <div id="dropdownUser" className="dropdown">
<button
className="btn dropdown-toggle"
role="button"
onReplyCancel?(): void;
allLanguages: Language[];
siteLanguages: number[];
+ containerClass?: string;
onUpsertComment(form: EditComment | CreateComment): void;
}
: undefined;
return (
- <div className="mb-3">
+ <div className={["mb-3", this.props.containerClass].join(" ")}>
{UserService.Instance.myUserInfo ? (
<MarkdownTextArea
initialContent={initialContent}
focus
allLanguages={this.props.allLanguages}
siteLanguages={this.props.siteLanguages}
+ containerClass="comment-comment-container"
onUpsertComment={this.props.onEditComment}
/>
)}
focus
allLanguages={this.props.allLanguages}
siteLanguages={this.props.siteLanguages}
+ containerClass="comment-comment-container"
onUpsertComment={this.props.onCreateComment}
/>
)}
MarkdownTextAreaProps,
MarkdownTextAreaState
> {
- private id = `comment-textarea-${randomStr()}`;
- private formId = `comment-form-${randomStr()}`;
+ private id = `markdown-textarea-${randomStr()}`;
+ private formId = `markdown-form-${randomStr()}`;
+
private tribute: any;
state: MarkdownTextAreaState = {
const myUSerInfo = UserService.Instance.myUserInfo;
const { name, actor_id } = this.props.community_view.community;
return (
- <div>
- <div className="card border-secondary mb-3">
+ <div id="sidebarContainer">
+ <div id="sidebarMain" className="card border-secondary mb-3">
<div className="card-body">
{this.communityTitle()}
{this.props.editable && this.adminButtons()}
)}
</div>
</div>
- <div className="card border-secondary mb-3">
+ <div id="sidebarInfo" className="card border-secondary mb-3">
<div className="card-body">
{this.description()}
{this.badges()}
return (
<div>
- <div>
- <div className="card border-secondary mb-3">
+ <div id="sidebarContainer">
+ <div id="sidebarMain" className="card border-secondary mb-3">
<div className="card-body">
{this.trendingCommunities()}
{canCreateCommunity(this.state.siteRes) && (
showLocal={showLocal(this.isoData)}
/>
{this.hasFollows && (
- <div className="card border-secondary mb-3">
+ <div id="sidebarSubscribed" className="card border-secondary mb-3">
<div className="card-body">{this.subscribedCommunities}</div>
</div>
)}
render() {
return (
- <div className="card border-secondary mb-3">
+ <div id="sidebarInfo" className="card border-secondary mb-3">
<div className="card-body">
<div>
<div className="mb-2">{this.siteName()}</div>
</h5>
) : (
<div className="row">
- <div className="col-12 col-lg-6 offset-lg-3 mb-4">
+ <div
+ id="createPostForm"
+ className="col-12 col-lg-6 offset-lg-3 mb-4"
+ >
<h5>{i18n.t("create_post")}</h5>
<PostForm
onCreate={this.handlePostCreate}
body() {
const body = this.postView.post.body;
return body ? (
- <div className="col-12 card my-2 p-2">
+ <div id="postContent" className="col-12 card my-2 p-2">
{this.state.viewSource ? (
<pre>{body}</pre>
) : (
</button>
{showScores() ? (
<div
- className={`unselectable pointer font-weight-bold text-muted px-1`}
+ className={`unselectable pointer font-weight-bold text-muted px-1 post-score`}
data-tippy-content={this.pointsTippy}
>
{numToSI(this.postView.counts.score)}
<>
{/* The mobile view*/}
<div className="d-block d-sm-none">
- <div className="row">
+ <div className="row post-container">
<div className="col-12">
{this.createdLine()}
{/* The larger view*/}
<div className="d-none d-sm-block">
- <div className="row">
+ <div className="row post-container">
{!this.props.viewOnly && this.voteBar()}
- <div className="col-sm-2 pr-0">
+ <div className="col-sm-2 pr-0 post-media">
<div className="">{this.thumbnail()}</div>
</div>
<div className="col-12 col-sm-9">
disabled={res.post_view.post.locked}
allLanguages={this.state.siteRes.all_languages}
siteLanguages={this.state.siteRes.discussion_languages}
+ containerClass="post-comment-container"
onUpsertComment={this.handleCreateComment}
finished={this.state.finished.get(0)}
/>