Skip to content
This repository has been archived by the owner on Sep 11, 2024. It is now read-only.

Commit

Permalink
Pillify permalinks
Browse files Browse the repository at this point in the history
  • Loading branch information
weeman1337 committed Mar 15, 2023
1 parent 209b652 commit dfe73ce
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 7 deletions.
5 changes: 1 addition & 4 deletions src/components/views/messages/TextualBody.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -92,11 +92,8 @@ export default class TextualBody extends React.Component<IBodyProps, IState> {
const showLineNumbers = SettingsStore.getValue("showCodeLineNumbers");
this.activateSpoilers([content]);

// pillifyLinks BEFORE linkifyElement because plain room/user URLs in the composer
// are still sent as plaintext URLs. If these are ever pillified in the composer,
// we should be pillify them here by doing the linkifying BEFORE the pillifying.
pillifyLinks([content], this.props.mxEvent, this.pills);
HtmlUtils.linkifyElement(content);
pillifyLinks([content], this.props.mxEvent, this.pills);

this.calculateUrlPreview();

Expand Down
24 changes: 21 additions & 3 deletions src/utils/pillify.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,25 @@ import { MatrixClientPeg } from "../MatrixClientPeg";
import SettingsStore from "../settings/SettingsStore";
import { Pill, PillType, pillRoomNotifLen, pillRoomNotifPos } from "../components/views/elements/Pill";
import { parsePermalink } from "./permalinks/Permalinks";
import { PermalinkParts } from "./permalinks/PermalinkConstructor";

/**
* A node here is an A element with a href attribute tag.
*
* It should not be pillified if the permalink parser result contains an event id.
*
* It should be pillified if the permalink parser returned a result and one of the following conditions match:
* - Text content equals href. This is the case when sending a plain permalink in a message.
* - The link does not have the "linkified" class.
* Composer completions already create an A tag.
* Linkify will not linkify things again. → There won't be a "linkified" class.
*/
const shouldBePillified = (node: Element, href: string, parts: PermalinkParts | null): boolean => {
if (!parts || parts.eventId) return;

const textContent = node.textContent;
return href === textContent || !node.classList.contains("linkified");
};

/**
* Recurses depth-first through a DOM tree, converting matrix.to links
Expand Down Expand Up @@ -51,9 +70,8 @@ export function pillifyLinks(nodes: ArrayLike<Element>, mxEvent: MatrixEvent, pi
} else if (node.tagName === "A" && node.getAttribute("href")) {
const href = node.getAttribute("href")!;
const parts = parsePermalink(href);
// If the link is a (localised) matrix.to link, replace it with a pill
// We don't want to pill event permalinks, so those are ignored.
if (parts && !parts.eventId) {

if (shouldBePillified(node, href, parts)) {
const pillContainer = document.createElement("span");

const pill = (
Expand Down

0 comments on commit dfe73ce

Please sign in to comment.