2020-10-21 00:23:55 +01:00
|
|
|
// This plugin is used only on mobile, to highlight search results.
|
|
|
|
|
2020-11-05 16:58:23 +00:00
|
|
|
import { RuleOptions } from '../../MdToHtml';
|
2020-10-21 00:23:55 +01:00
|
|
|
|
2020-01-30 21:05:23 +00:00
|
|
|
const stringUtils = require('../../stringUtils.js');
|
|
|
|
const md5 = require('md5');
|
|
|
|
|
2020-11-12 19:13:28 +00:00
|
|
|
function createHighlightedTokens(Token: any, splitted: string[]) {
|
2020-01-30 21:05:23 +00:00
|
|
|
let token;
|
|
|
|
const output = [];
|
|
|
|
|
|
|
|
for (let i = 0; i < splitted.length; i++) {
|
|
|
|
const text = splitted[i];
|
|
|
|
if (!text) continue;
|
|
|
|
|
|
|
|
if (i % 2 === 0) {
|
|
|
|
token = new Token('text', '', 0);
|
|
|
|
token.content = text;
|
|
|
|
output.push(token);
|
|
|
|
} else {
|
|
|
|
token = new Token('highlighted_keyword_open', 'span', 1);
|
|
|
|
token.attrs = [['class', 'highlighted-keyword']];
|
|
|
|
output.push(token);
|
|
|
|
|
|
|
|
token = new Token('text', '', 0);
|
|
|
|
token.content = text;
|
|
|
|
output.push(token);
|
|
|
|
|
|
|
|
token = new Token('highlighted_keyword_close', 'span', -1);
|
|
|
|
output.push(token);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return output;
|
|
|
|
}
|
|
|
|
|
2020-10-21 00:23:55 +01:00
|
|
|
// function installRule(markdownIt, mdOptions, ruleOptions) {
|
2020-11-12 19:13:28 +00:00
|
|
|
function plugin(markdownIt: any, ruleOptions: RuleOptions) {
|
2020-01-30 21:05:23 +00:00
|
|
|
const divider = md5(Date.now().toString() + Math.random().toString());
|
|
|
|
|
2020-11-12 19:13:28 +00:00
|
|
|
markdownIt.core.ruler.push('highlight_keywords', (state: any) => {
|
2020-01-30 21:05:23 +00:00
|
|
|
const keywords = ruleOptions.highlightedKeywords;
|
|
|
|
if (!keywords || !keywords.length) return;
|
|
|
|
|
|
|
|
const tokens = state.tokens;
|
|
|
|
const Token = state.Token;
|
|
|
|
|
|
|
|
for (let i = 0; i < tokens.length; i++) {
|
|
|
|
const token = tokens[i];
|
|
|
|
|
|
|
|
if (token.type !== 'inline') continue;
|
|
|
|
|
|
|
|
for (let j = 0; j < token.children.length; j++) {
|
|
|
|
const child = token.children[j];
|
|
|
|
if (child.type !== 'text') continue;
|
|
|
|
|
|
|
|
const splitted = stringUtils.surroundKeywords(keywords, child.content, divider, divider).split(divider);
|
|
|
|
const splittedTokens = createHighlightedTokens(Token, splitted);
|
|
|
|
if (splittedTokens.length <= 1) continue;
|
|
|
|
|
|
|
|
token.children = markdownIt.utils.arrayReplaceAt(token.children, j, splittedTokens);
|
|
|
|
j += splittedTokens.length - 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2020-10-21 00:23:55 +01:00
|
|
|
export default {
|
|
|
|
plugin,
|
2020-10-24 00:14:30 +01:00
|
|
|
};
|