mirror of
https://github.com/flarum/framework.git
synced 2024-12-12 14:13:37 +08:00
Fix discussion search result suggestion excerpts
So that they show the relevant part of the post
This commit is contained in:
parent
85cd2663e3
commit
e62093f4dd
|
@ -29,7 +29,7 @@ export default class DiscussionsSearchResults {
|
|||
return m('li.discussion-search-result', {'data-index': 'discussions'+discussion.id()},
|
||||
m('a', { href: app.route.discussion(discussion, post && post.number()), config: m.route },
|
||||
m('div.title', highlight(discussion.title(), string)),
|
||||
post ? m('div.excerpt', highlight(truncate(post.contentPlain(), 100), string)) : ''
|
||||
post ? m('div.excerpt', highlight(post.contentPlain(), string, 100)) : ''
|
||||
)
|
||||
);
|
||||
}) : ''
|
||||
|
|
|
@ -1,13 +1,21 @@
|
|||
export default function(string, regexp) {
|
||||
if (!regexp) {
|
||||
import truncate from '../utils/truncate';
|
||||
|
||||
export default function(string, phrase, length) {
|
||||
if (!phrase) {
|
||||
return string;
|
||||
}
|
||||
|
||||
if (!(regexp instanceof RegExp)) {
|
||||
regexp = new RegExp(regexp, 'gi');
|
||||
const regexp = regexp instanceof RegExp ? phrase : new RegExp(phrase, 'gi');
|
||||
|
||||
let highlightedString = string;
|
||||
let start = 0;
|
||||
|
||||
if (length) {
|
||||
start = Math.max(0, string.search(regexp) - length / 2);
|
||||
highlightedString = truncate(highlightedString, length, start);
|
||||
}
|
||||
|
||||
return m.trust(
|
||||
$('<div/>').text(string).html().replace(regexp, '<mark>$&</mark>')
|
||||
);
|
||||
highlightedString = $('<div/>').text(highlightedString).html().replace(regexp, '<mark>$&</mark>');
|
||||
|
||||
return m.trust(highlightedString);
|
||||
}
|
||||
|
|
|
@ -1,6 +1,5 @@
|
|||
export default function truncate(string, length, start) {
|
||||
start = start || 0;
|
||||
string = string || '';
|
||||
|
||||
return (start > 0 ? '...' : '')+string.substring(start, start + length)+(string.length > start + length ? '...' : '');
|
||||
export default function truncate(string = '', length, start = 0) {
|
||||
return (start > 0 ? '...' : '') +
|
||||
string.substring(start, start + length) +
|
||||
(string.length > start + length ? '...' : '');
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue
Block a user