mirror of
https://github.com/mattermost/focalboard.git
synced 2025-01-20 18:28:25 +02:00
GH-1878: Display Bot Badge in Auto Complete (#1906)
This commit is contained in:
parent
c8d4c98f8c
commit
dc36afcfba
@ -47,6 +47,10 @@ type User struct {
|
||||
// Deleted time, set to indicate user is deleted
|
||||
// required: true
|
||||
DeleteAt int64 `json:"delete_at"`
|
||||
|
||||
// If the user is a bot or not
|
||||
// required: true
|
||||
IsBot bool `json:"is_bot"`
|
||||
}
|
||||
|
||||
type Session struct {
|
||||
|
@ -284,10 +284,11 @@ func (s *MattermostAuthLayer) getQueryBuilder() sq.StatementBuilderType {
|
||||
func (s *MattermostAuthLayer) GetUsersByWorkspace(workspaceID string) ([]*model.User, error) {
|
||||
query := s.getQueryBuilder().
|
||||
Select("id", "username", "email", "password", "MFASecret as mfa_secret", "AuthService as auth_service", "COALESCE(AuthData, '') as auth_data",
|
||||
"props", "CreateAt as create_at", "UpdateAt as update_at", "DeleteAt as delete_at").
|
||||
"props", "Users.CreateAt as create_at", "Users.UpdateAt as update_at", "Users.DeleteAt as delete_at", "b.UserId IS NOT NULL AS is_bot").
|
||||
From("Users").
|
||||
Join("ChannelMembers ON ChannelMembers.UserID = Users.ID").
|
||||
Where(sq.Eq{"deleteAt": 0}).
|
||||
LeftJoin("Bots b ON ( b.UserId = Users.ID )").
|
||||
Where(sq.Eq{"Users.deleteAt": 0}).
|
||||
Where(sq.Eq{"ChannelMembers.ChannelId": workspaceID})
|
||||
|
||||
rows, err := query.Query()
|
||||
@ -323,6 +324,7 @@ func (s *MattermostAuthLayer) usersFromRows(rows *sql.Rows) ([]*model.User, erro
|
||||
&user.CreateAt,
|
||||
&user.UpdateAt,
|
||||
&user.DeleteAt,
|
||||
&user.IsBot,
|
||||
)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
|
@ -0,0 +1,5 @@
|
||||
.EntryComponent {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
}
|
@ -0,0 +1,39 @@
|
||||
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
||||
// See LICENSE.txt for license information.
|
||||
import React, {ReactElement} from 'react'
|
||||
import {EntryComponentProps} from '@draft-js-plugins/mention/lib/MentionSuggestions/Entry/Entry'
|
||||
import './entryComponent.scss'
|
||||
|
||||
const BotBadge = (window as any).Components?.BotBadge
|
||||
|
||||
const Entry = (props: EntryComponentProps): ReactElement => {
|
||||
const {
|
||||
mention,
|
||||
theme,
|
||||
...parentProps
|
||||
} = props
|
||||
|
||||
return (
|
||||
<div
|
||||
{...parentProps}
|
||||
>
|
||||
<div className={`${theme?.mentionSuggestionsEntryContainer} EntryComponent`}>
|
||||
<img
|
||||
src={mention.avatar}
|
||||
className={theme?.mentionSuggestionsEntryAvatar}
|
||||
role='presentation'
|
||||
/>
|
||||
<div className={theme?.mentionSuggestionsEntryText}>
|
||||
{mention.name}
|
||||
{BotBadge &&
|
||||
<BotBadge
|
||||
show={mention.isBot}
|
||||
/>
|
||||
}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
)
|
||||
}
|
||||
|
||||
export default Entry
|
@ -24,6 +24,8 @@ import {getWorkspaceUsersList} from '../../store/users'
|
||||
import {useAppSelector} from '../../store/hooks'
|
||||
import {IUser} from '../../user'
|
||||
|
||||
import Entry from './entryComponent/entryComponent'
|
||||
|
||||
const imageURLForUser = (window as any).Components?.imageURLForUser
|
||||
|
||||
type Props = {
|
||||
@ -38,7 +40,14 @@ type Props = {
|
||||
const MarkdownEditorInput = (props: Props): ReactElement => {
|
||||
const {onChange, onFocus, onBlur, initialText, id, isEditing} = props
|
||||
const workspaceUsers = useAppSelector<IUser[]>(getWorkspaceUsersList)
|
||||
const mentions: MentionData[] = useMemo(() => workspaceUsers.map((user) => ({name: user.username, avatar: `${imageURLForUser ? imageURLForUser(user.id) : ''}`})), [workspaceUsers])
|
||||
const mentions: MentionData[] = useMemo(() =>
|
||||
workspaceUsers.map((user) =>
|
||||
({
|
||||
name: user.username,
|
||||
avatar: `${imageURLForUser ? imageURLForUser(user.id) : ''}`,
|
||||
isBot: user.is_bot,
|
||||
}))
|
||||
, [workspaceUsers])
|
||||
const ref = useRef<Editor>(null)
|
||||
const [editorState, setEditorState] = useState(() => {
|
||||
const state = EditorState.createWithContent(ContentState.createFromText(initialText || ''))
|
||||
@ -160,6 +169,7 @@ const MarkdownEditorInput = (props: Props): ReactElement => {
|
||||
onOpenChange={onMentionPopoverOpenChange}
|
||||
suggestions={suggestions}
|
||||
onSearchChange={onSearchChange}
|
||||
entryComponent={Entry}
|
||||
/>
|
||||
<EmojiSuggestions
|
||||
onOpen={onEmojiPopoverOpen}
|
||||
|
@ -75,7 +75,7 @@ card3.id = 'card3'
|
||||
card3.title = 'card-3'
|
||||
card3.workspaceId = workspace1.id
|
||||
|
||||
const me: IUser = {id: 'user-id-1', username: 'username_1', email: '', props: {}, createAt: 0, updateAt: 0}
|
||||
const me: IUser = {id: 'user-id-1', username: 'username_1', email: '', props: {}, create_at: 0, update_at: 0, is_bot: false}
|
||||
|
||||
jest.mock('react-router-dom', () => {
|
||||
const originalModule = jest.requireActual('react-router-dom')
|
||||
|
@ -7,8 +7,9 @@ interface IUser {
|
||||
email: string,
|
||||
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
||||
props: Record<string, any>,
|
||||
createAt: number,
|
||||
updateAt: number,
|
||||
create_at: number,
|
||||
update_at: number,
|
||||
is_bot: boolean,
|
||||
}
|
||||
|
||||
interface UserWorkspace {
|
||||
|
Loading…
x
Reference in New Issue
Block a user