mirror of
https://github.com/owncast/owncast.git
synced 2025-01-23 00:23:54 +03:00
45 lines
916 B
TypeScript
45 lines
916 B
TypeScript
|
/* eslint-disable class-methods-use-this */
|
||
|
import { ChildrenNode, Matcher, MatchResponse, Node } from 'interweave';
|
||
|
import React from 'react';
|
||
|
|
||
|
export interface CustomProps {
|
||
|
children: React.ReactNode;
|
||
|
key: string;
|
||
|
}
|
||
|
|
||
|
interface options {
|
||
|
highlightString: string;
|
||
|
}
|
||
|
|
||
|
export class ChatMessageHighlightMatcher extends Matcher {
|
||
|
match(str: string): MatchResponse<{}> | null {
|
||
|
const { highlightString } = this.options as options;
|
||
|
|
||
|
if (!highlightString) {
|
||
|
return null;
|
||
|
}
|
||
|
|
||
|
const result = str.match(highlightString);
|
||
|
|
||
|
if (!result) {
|
||
|
return null;
|
||
|
}
|
||
|
|
||
|
return {
|
||
|
index: result.index!,
|
||
|
length: result[0].length,
|
||
|
match: result[0],
|
||
|
valid: true,
|
||
|
};
|
||
|
}
|
||
|
|
||
|
replaceWith(children: ChildrenNode, props: CustomProps): Node {
|
||
|
const { key } = props;
|
||
|
return React.createElement('mark', { key }, children);
|
||
|
}
|
||
|
|
||
|
asTag(): string {
|
||
|
return 'mark';
|
||
|
}
|
||
|
}
|