zulip/web/src/message_parser.ts
Kenneth Rodrigues f53a7cdffa reaction-view: Create has reaction operator.
Create has:reaction search operator and search suggestions.
Create sidebar view for the user to view their messages that
have reactions using has:reaction sender:me operators.
Add custom heading for the view and tooltip in the sidebar.
Add documentation for the new operator.

Fixes: #27328.
2024-06-10 11:46:37 -07:00

30 lines
1.1 KiB
TypeScript

// We only use jquery for parsing.
import $ from "jquery";
import type {Message} from "./message_store";
// We need to check if the message content contains the specified HTML
// elements. We wrap the message.content in a <div>; this is
// important because $("Text <a>link</a>").find("a") returns nothing;
// one needs an outer element wrapping an object to use this
// construction.
function is_element_in_message_content(message: Message, element_selector: string): boolean {
return $(`<div>${message.content}</div>`).find(element_selector).length > 0;
}
export function message_has_link(message: Message): boolean {
return is_element_in_message_content(message, "a");
}
export function message_has_image(message: Message): boolean {
return is_element_in_message_content(message, ".message_inline_image");
}
export function message_has_attachment(message: Message): boolean {
return is_element_in_message_content(message, "a[href^='/user_uploads']");
}
export function message_has_reaction(message: Message): boolean {
return message.clean_reactions.size > 0;
}