1
0
Fork 0
mirror of https://github.com/LemmyNet/lemmy-ui.git synced 2025-01-23 22:26:46 +00:00

Adding mod / admin distinguish. (#744)

This commit is contained in:
Dessalines 2022-08-17 19:26:50 -04:00 committed by GitHub
parent 920a35383b
commit 3bf1cc2797
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
7 changed files with 77 additions and 13 deletions

@ -1 +1 @@
Subproject commit 7c3945745dcd07774b19453803f7f14ab80ab3d3 Subproject commit 9ba11fa31001baac6bacb4eea651942cc48d41a9

View file

@ -77,7 +77,7 @@
"eslint-plugin-prettier": "^4.2.1", "eslint-plugin-prettier": "^4.2.1",
"husky": "^8.0.1", "husky": "^8.0.1",
"import-sort-style-module": "^6.0.0", "import-sort-style-module": "^6.0.0",
"lemmy-js-client": "0.17.0-rc.39", "lemmy-js-client": "0.17.0-rc.41",
"lint-staged": "^13.0.3", "lint-staged": "^13.0.3",
"mini-css-extract-plugin": "^2.6.1", "mini-css-extract-plugin": "^2.6.1",
"node-fetch": "^2.6.1", "node-fetch": "^2.6.1",

View file

@ -112,7 +112,8 @@ export class CommentForm extends Component<CommentFormProps, CommentFormState> {
left: node => { left: node => {
if (this.props.edit) { if (this.props.edit) {
let form = new EditComment({ let form = new EditComment({
content, content: Some(content),
distinguished: None,
form_id: this.state.formId, form_id: this.state.formId,
comment_id: node.comment_view.comment.id, comment_id: node.comment_view.comment.id,
auth: auth().unwrap(), auth: auth().unwrap(),

View file

@ -15,6 +15,7 @@ import {
CreateCommentLike, CreateCommentLike,
CreateCommentReport, CreateCommentReport,
DeleteComment, DeleteComment,
EditComment,
GetComments, GetComments,
ListingType, ListingType,
MarkCommentReplyAsRead, MarkCommentReplyAsRead,
@ -171,7 +172,20 @@ export class CommentNode extends Component<CommentNodeProps, CommentNodeState> {
this.props.admins, this.props.admins,
cv.creator.id cv.creator.id
); );
let canModOnSelf = canMod(
this.props.moderators,
this.props.admins,
cv.creator.id,
UserService.Instance.myUserInfo,
true
);
let canAdmin_ = canAdmin(this.props.admins, cv.creator.id); let canAdmin_ = canAdmin(this.props.admins, cv.creator.id);
let canAdminOnSelf = canAdmin(
this.props.admins,
cv.creator.id,
UserService.Instance.myUserInfo,
true
);
let isMod_ = isMod(this.props.moderators, cv.creator.id); let isMod_ = isMod(this.props.moderators, cv.creator.id);
let isAdmin_ = isAdmin(this.props.admins, cv.creator.id); let isAdmin_ = isAdmin(this.props.admins, cv.creator.id);
let amCommunityCreator_ = amCommunityCreator( let amCommunityCreator_ = amCommunityCreator(
@ -200,9 +214,12 @@ export class CommentNode extends Component<CommentNodeProps, CommentNodeState> {
> >
<div <div
id={`comment-${cv.comment.id}`} id={`comment-${cv.comment.id}`}
className={`details comment-node py-2 ${ className={classNames(`details comment-node py-2`, {
!this.props.noBorder ? "border-top border-light" : "" "border-top border-light": !this.props.noBorder,
} ${this.isCommentNew ? "mark" : ""}`} mark:
this.isCommentNew ||
this.props.node.comment_view.comment.distinguished,
})}
style={ style={
!this.props.noIndent && !this.props.noIndent &&
this.props.node.depth && this.props.node.depth &&
@ -216,7 +233,9 @@ export class CommentNode extends Component<CommentNodeProps, CommentNodeState> {
<span class="mr-2"> <span class="mr-2">
<PersonListing person={cv.creator} /> <PersonListing person={cv.creator} />
</span> </span>
{cv.comment.distinguished && (
<Icon icon="shield" inline classes={`text-danger mr-2`} />
)}
{isMod_ && ( {isMod_ && (
<div className="badge badge-light d-none d-sm-inline mr-2"> <div className="badge badge-light d-none d-sm-inline mr-2">
{i18n.t("mod")} {i18n.t("mod")}
@ -516,6 +535,34 @@ export class CommentNode extends Component<CommentNodeProps, CommentNodeState> {
}`} }`}
/> />
</button> </button>
{(canModOnSelf || canAdminOnSelf) && (
<button
class="btn btn-link btn-animate text-muted"
onClick={linkEvent(
this,
this.handleDistinguishClick
)}
data-tippy-content={
!cv.comment.distinguished
? i18n.t("distinguish")
: i18n.t("undistinguish")
}
aria-label={
!cv.comment.distinguished
? i18n.t("distinguish")
: i18n.t("undistinguish")
}
>
<Icon
icon="shield"
classes={`icon-inline ${
cv.comment.distinguished &&
"text-danger"
}`}
/>
</button>
)}
</> </>
)} )}
{/* Admins and mods can remove comments */} {/* Admins and mods can remove comments */}
@ -1204,6 +1251,19 @@ export class CommentNode extends Component<CommentNodeProps, CommentNodeState> {
i.setState(i.state); i.setState(i.state);
} }
handleDistinguishClick(i: CommentNode) {
let comment = i.props.node.comment_view.comment;
let form = new EditComment({
comment_id: comment.id,
form_id: None, // TODO not sure about this
content: None,
distinguished: Some(!comment.distinguished),
auth: auth().unwrap(),
});
WebSocketService.Instance.send(wsClient.editComment(form));
i.setState(i.state);
}
isPersonMentionType( isPersonMentionType(
item: CommentView | PersonMentionView | CommentReplyView item: CommentView | PersonMentionView | CommentReplyView
): item is PersonMentionView { ): item is PersonMentionView {

View file

@ -721,6 +721,7 @@ export class Post extends Component<any, PostState> {
this.state.commentsRes.map(r => r.comments).unwrapOr([]) this.state.commentsRes.map(r => r.comments).unwrapOr([])
); );
this.setState(this.state); this.setState(this.state);
setupTippy();
} else if (op == UserOperation.SaveComment) { } else if (op == UserOperation.SaveComment) {
let data = wsJsonToRes<CommentResponse>(msg, CommentResponse); let data = wsJsonToRes<CommentResponse>(msg, CommentResponse);
saveCommentRes( saveCommentRes(

View file

@ -210,9 +210,10 @@ export function canMod(
export function canAdmin( export function canAdmin(
admins: Option<PersonViewSafe[]>, admins: Option<PersonViewSafe[]>,
creator_id: number, creator_id: number,
myUserInfo = UserService.Instance.myUserInfo myUserInfo = UserService.Instance.myUserInfo,
onSelf = false
): boolean { ): boolean {
return canMod(None, admins, creator_id, myUserInfo); return canMod(None, admins, creator_id, myUserInfo, onSelf);
} }
export function isMod( export function isMod(
@ -830,6 +831,7 @@ export function editCommentRes(data: CommentView, comments: CommentView[]) {
let found = comments.find(c => c.comment.id == data.comment.id); let found = comments.find(c => c.comment.id == data.comment.id);
if (found) { if (found) {
found.comment.content = data.comment.content; found.comment.content = data.comment.content;
found.comment.distinguished = data.comment.distinguished;
found.comment.updated = data.comment.updated; found.comment.updated = data.comment.updated;
found.comment.removed = data.comment.removed; found.comment.removed = data.comment.removed;
found.comment.deleted = data.comment.deleted; found.comment.deleted = data.comment.deleted;

View file

@ -5056,10 +5056,10 @@ lcid@^1.0.0:
dependencies: dependencies:
invert-kv "^1.0.0" invert-kv "^1.0.0"
lemmy-js-client@0.17.0-rc.39: lemmy-js-client@0.17.0-rc.41:
version "0.17.0-rc.39" version "0.17.0-rc.41"
resolved "https://registry.yarnpkg.com/lemmy-js-client/-/lemmy-js-client-0.17.0-rc.39.tgz#b17c5c0d9a0f36c90c17be99845a5703091ab306" resolved "https://registry.yarnpkg.com/lemmy-js-client/-/lemmy-js-client-0.17.0-rc.41.tgz#a72bd41b76af834d97914d3790810efa610a6e89"
integrity sha512-MsKavo5xOob6DgfjyhbmXyFvXwdW4iwftStJ7Bz3ArlHXy6zGBp+2uy2rU2c5ujivNDX72ol3TupTHBtSXLs4w== integrity sha512-VJ0qMXaEuOvmUxWR/jWnnoWknpNSXxbz/J29ADTn9arJEbOfTQB60ILeg8wICSRI23jzU9/0lqAZ+rjgXN0p4w==
levn@^0.4.1: levn@^0.4.1:
version "0.4.1" version "0.4.1"