mizzkey/src/api/common/text/index.ts

72 lines
1.2 KiB
TypeScript
Raw Normal View History

2016-12-28 23:49:51 +01:00
/**
* Misskey Text Analyzer
*/
const elements = [
require('./elements/bold'),
require('./elements/url'),
2017-03-17 17:16:32 +01:00
require('./elements/link'),
2016-12-28 23:49:51 +01:00
require('./elements/mention'),
2017-02-08 17:07:06 +01:00
require('./elements/hashtag'),
2017-02-11 15:41:57 +01:00
require('./elements/code'),
require('./elements/inline-code'),
require('./elements/emoji')
2016-12-28 23:49:51 +01:00
];
2017-03-18 12:05:11 +01:00
export default (source: string) => {
2016-12-28 23:49:51 +01:00
if (source == '') {
return null;
}
const tokens = [];
function push(token) {
if (token != null) {
tokens.push(token);
source = source.substr(token.content.length);
}
}
let i = 0;
// パース
while (source != '') {
const parsed = elements.some(el => {
2017-02-10 18:32:00 +01:00
let tokens = el(source, i);
if (tokens) {
2016-12-28 23:49:51 +01:00
if (!Array.isArray(tokens)) {
tokens = [tokens];
}
tokens.forEach(push);
return true;
2017-03-18 12:05:11 +01:00
} else {
return false;
2016-12-28 23:49:51 +01:00
}
});
if (!parsed) {
push({
type: 'text',
content: source[0]
});
}
i++;
}
// テキストを纏める
tokens[0] = [tokens[0]];
return tokens.reduce((a, b) => {
if (a[a.length - 1].type == 'text' && b.type == 'text') {
const tail = a.pop();
return a.concat({
type: 'text',
content: tail.content + b.content
});
} else {
return a.concat(b);
}
});
2017-03-18 12:05:11 +01:00
};