refactor: add url token and fix telegram adapt problem
This commit is contained in:
parent
5b826cab34
commit
e6f02677e5
@ -22,7 +22,7 @@ export const telegram: NotificationProvider = {
|
|||||||
await axios.post(`https://api.telegram.org/bot${botToken}/sendMessage`, {
|
await axios.post(`https://api.telegram.org/bot${botToken}/sendMessage`, {
|
||||||
chat_id: chatId,
|
chat_id: chatId,
|
||||||
text,
|
text,
|
||||||
parse_mode: 'MarkdownV2',
|
parse_mode: 'HTML',
|
||||||
});
|
});
|
||||||
|
|
||||||
// send image
|
// send image
|
||||||
|
@ -9,6 +9,7 @@ import {
|
|||||||
ParagraphContentToken,
|
ParagraphContentToken,
|
||||||
TextContentToken,
|
TextContentToken,
|
||||||
TitleContentToken,
|
TitleContentToken,
|
||||||
|
UrlContentToken,
|
||||||
} from './type';
|
} from './type';
|
||||||
|
|
||||||
export type { ContentToken };
|
export type { ContentToken };
|
||||||
@ -34,6 +35,11 @@ export const token = {
|
|||||||
newline: (): NewlineContentToken => ({
|
newline: (): NewlineContentToken => ({
|
||||||
type: 'newline',
|
type: 'newline',
|
||||||
}),
|
}),
|
||||||
|
url: (url: string, title?: string): UrlContentToken => ({
|
||||||
|
type: 'url',
|
||||||
|
url,
|
||||||
|
title,
|
||||||
|
}),
|
||||||
};
|
};
|
||||||
|
|
||||||
export const baseContentTokenizer = new BaseContentTokenizer();
|
export const baseContentTokenizer = new BaseContentTokenizer();
|
||||||
|
@ -5,6 +5,7 @@ import {
|
|||||||
ParagraphContentToken,
|
ParagraphContentToken,
|
||||||
TextContentToken,
|
TextContentToken,
|
||||||
TitleContentToken,
|
TitleContentToken,
|
||||||
|
UrlContentToken,
|
||||||
} from '../type';
|
} from '../type';
|
||||||
|
|
||||||
export class BaseContentTokenizer {
|
export class BaseContentTokenizer {
|
||||||
@ -28,6 +29,10 @@ export class BaseContentTokenizer {
|
|||||||
return '\n';
|
return '\n';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
parseUrl(token: UrlContentToken) {
|
||||||
|
return token.url;
|
||||||
|
}
|
||||||
|
|
||||||
parse(tokens: ContentToken[]) {
|
parse(tokens: ContentToken[]) {
|
||||||
return tokens
|
return tokens
|
||||||
.map((token) => {
|
.map((token) => {
|
||||||
|
@ -3,6 +3,7 @@ import {
|
|||||||
NewlineContentToken,
|
NewlineContentToken,
|
||||||
ParagraphContentToken,
|
ParagraphContentToken,
|
||||||
TitleContentToken,
|
TitleContentToken,
|
||||||
|
UrlContentToken,
|
||||||
} from '../type';
|
} from '../type';
|
||||||
import { BaseContentTokenizer } from './base';
|
import { BaseContentTokenizer } from './base';
|
||||||
|
|
||||||
@ -32,4 +33,8 @@ export class HTMLContentTokenizer extends BaseContentTokenizer {
|
|||||||
parseNewline(token: NewlineContentToken) {
|
parseNewline(token: NewlineContentToken) {
|
||||||
return '<br />';
|
return '<br />';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
parseUrl(token: UrlContentToken): string {
|
||||||
|
return `<a href="${token.url}">${token.title ?? token.url}</a>`;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -2,6 +2,7 @@ import {
|
|||||||
ImageContentToken,
|
ImageContentToken,
|
||||||
ParagraphContentToken,
|
ParagraphContentToken,
|
||||||
TitleContentToken,
|
TitleContentToken,
|
||||||
|
UrlContentToken,
|
||||||
} from '../type';
|
} from '../type';
|
||||||
import { BaseContentTokenizer } from './base';
|
import { BaseContentTokenizer } from './base';
|
||||||
|
|
||||||
@ -27,4 +28,8 @@ export class MarkdownContentTokenizer extends BaseContentTokenizer {
|
|||||||
|
|
||||||
return `\n${token.content}\n`;
|
return `\n${token.content}\n`;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
parseUrl(token: UrlContentToken): string {
|
||||||
|
return `[${token.title ?? ''}](${token.url})`;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,22 +1,37 @@
|
|||||||
import { ImageContentToken, TitleContentToken } from '../type';
|
import {
|
||||||
import { MarkdownContentTokenizer } from './markdown';
|
ImageContentToken,
|
||||||
|
ParagraphContentToken,
|
||||||
|
TextContentToken,
|
||||||
|
TitleContentToken,
|
||||||
|
UrlContentToken,
|
||||||
|
} from '../type';
|
||||||
|
import { BaseContentTokenizer } from './base';
|
||||||
|
|
||||||
export class TelegramContentTokenizer extends MarkdownContentTokenizer {
|
export class TelegramContentTokenizer extends BaseContentTokenizer {
|
||||||
parseImage(token: ImageContentToken) {
|
parseImage(token: ImageContentToken) {
|
||||||
return '';
|
return '';
|
||||||
}
|
}
|
||||||
|
|
||||||
parseTitle(token: TitleContentToken) {
|
parseText(token: TextContentToken): string {
|
||||||
if (token.level === 1) {
|
return this.parseEntityCharacter(token.content);
|
||||||
return `\n\\# ${token.content}\n`;
|
}
|
||||||
}
|
|
||||||
if (token.level === 2) {
|
|
||||||
return `\n\\#\\# ${token.content}\n`;
|
|
||||||
}
|
|
||||||
if (token.level === 3) {
|
|
||||||
return `\n\\#\\#\\# ${token.content}\n`;
|
|
||||||
}
|
|
||||||
|
|
||||||
return `\n${token.content}\n`;
|
parseTitle(token: TitleContentToken) {
|
||||||
|
return `\n<b>${this.parseEntityCharacter(token.content)}</b>\n`;
|
||||||
|
}
|
||||||
|
|
||||||
|
parseParagraph(token: ParagraphContentToken) {
|
||||||
|
return `\n${this.parseEntityCharacter(token.content)}\n`;
|
||||||
|
}
|
||||||
|
|
||||||
|
parseUrl(token: UrlContentToken): string {
|
||||||
|
return `<a href="${token.url}">${token.title ?? token.url}</a>`;
|
||||||
|
}
|
||||||
|
|
||||||
|
private parseEntityCharacter(input: string): string {
|
||||||
|
return input
|
||||||
|
.replaceAll('<', '<')
|
||||||
|
.replaceAll('>', '>')
|
||||||
|
.replaceAll('&', '&');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -23,9 +23,16 @@ export type NewlineContentToken = {
|
|||||||
type: 'newline';
|
type: 'newline';
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export type UrlContentToken = {
|
||||||
|
type: 'url';
|
||||||
|
url: string;
|
||||||
|
title?: string;
|
||||||
|
};
|
||||||
|
|
||||||
export type ContentToken =
|
export type ContentToken =
|
||||||
| TextContentToken
|
| TextContentToken
|
||||||
| ImageContentToken
|
| ImageContentToken
|
||||||
| TitleContentToken
|
| TitleContentToken
|
||||||
| ParagraphContentToken
|
| ParagraphContentToken
|
||||||
| NewlineContentToken;
|
| NewlineContentToken
|
||||||
|
| UrlContentToken;
|
||||||
|
Loading…
Reference in New Issue
Block a user