forked from mirror/misskey
refactor
This commit is contained in:
parent
7173deaa01
commit
ee22820da2
@ -14,7 +14,6 @@ import EmEmoji from '@/components/EmEmoji.vue';
|
|||||||
import EmCustomEmoji from '@/components/EmCustomEmoji.vue';
|
import EmCustomEmoji from '@/components/EmCustomEmoji.vue';
|
||||||
import EmA from '@/components/EmA.vue';
|
import EmA from '@/components/EmA.vue';
|
||||||
import { host } from '@/config.js';
|
import { host } from '@/config.js';
|
||||||
import { nyaize as doNyaize } from '@/to-be-shared/nyaize.js';
|
|
||||||
import { safeParseFloat } from '@/to-be-shared/safe-parse.js';
|
import { safeParseFloat } from '@/to-be-shared/safe-parse.js';
|
||||||
|
|
||||||
const QUOTE_STYLE = `
|
const QUOTE_STYLE = `
|
||||||
@ -81,7 +80,7 @@ export default function (props: MfmProps, { emit }: { emit: SetupContext<MfmEven
|
|||||||
case 'text': {
|
case 'text': {
|
||||||
let text = token.props.text.replace(/(\r\n|\n|\r)/g, '\n');
|
let text = token.props.text.replace(/(\r\n|\n|\r)/g, '\n');
|
||||||
if (!disableNyaize && shouldNyaize) {
|
if (!disableNyaize && shouldNyaize) {
|
||||||
text = doNyaize(text);
|
text = Misskey.nyaize(text);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!props.plain) {
|
if (!props.plain) {
|
||||||
@ -271,14 +270,14 @@ export default function (props: MfmProps, { emit }: { emit: SetupContext<MfmEven
|
|||||||
const child = token.children[0];
|
const child = token.children[0];
|
||||||
let text = child.type === 'text' ? child.props.text : '';
|
let text = child.type === 'text' ? child.props.text : '';
|
||||||
if (!disableNyaize && shouldNyaize) {
|
if (!disableNyaize && shouldNyaize) {
|
||||||
text = doNyaize(text);
|
text = Misskey.nyaize(text);
|
||||||
}
|
}
|
||||||
return h('ruby', {}, [text.split(' ')[0], h('rt', text.split(' ')[1])]);
|
return h('ruby', {}, [text.split(' ')[0], h('rt', text.split(' ')[1])]);
|
||||||
} else {
|
} else {
|
||||||
const rt = token.children.at(-1)!;
|
const rt = token.children.at(-1)!;
|
||||||
let text = rt.type === 'text' ? rt.props.text : '';
|
let text = rt.type === 'text' ? rt.props.text : '';
|
||||||
if (!disableNyaize && shouldNyaize) {
|
if (!disableNyaize && shouldNyaize) {
|
||||||
text = doNyaize(text);
|
text = Misskey.nyaize(text);
|
||||||
}
|
}
|
||||||
return h('ruby', {}, [...genEl(token.children.slice(0, token.children.length - 1), scale), h('rt', text.trim())]);
|
return h('ruby', {}, [...genEl(token.children.slice(0, token.children.length - 1), scale), h('rt', text.trim())]);
|
||||||
}
|
}
|
||||||
|
@ -19,7 +19,6 @@ import MkSparkle from '@/components/MkSparkle.vue';
|
|||||||
import MkA, { MkABehavior } from '@/components/global/MkA.vue';
|
import MkA, { MkABehavior } from '@/components/global/MkA.vue';
|
||||||
import { host } from '@/config.js';
|
import { host } from '@/config.js';
|
||||||
import { defaultStore } from '@/store.js';
|
import { defaultStore } from '@/store.js';
|
||||||
import { nyaize as doNyaize } from '@/scripts/nyaize.js';
|
|
||||||
import { safeParseFloat } from '@/scripts/safe-parse.js';
|
import { safeParseFloat } from '@/scripts/safe-parse.js';
|
||||||
|
|
||||||
const QUOTE_STYLE = `
|
const QUOTE_STYLE = `
|
||||||
@ -86,7 +85,7 @@ export default function (props: MfmProps, { emit }: { emit: SetupContext<MfmEven
|
|||||||
case 'text': {
|
case 'text': {
|
||||||
let text = token.props.text.replace(/(\r\n|\n|\r)/g, '\n');
|
let text = token.props.text.replace(/(\r\n|\n|\r)/g, '\n');
|
||||||
if (!disableNyaize && shouldNyaize) {
|
if (!disableNyaize && shouldNyaize) {
|
||||||
text = doNyaize(text);
|
text = Misskey.nyaize(text);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!props.plain) {
|
if (!props.plain) {
|
||||||
@ -281,14 +280,14 @@ export default function (props: MfmProps, { emit }: { emit: SetupContext<MfmEven
|
|||||||
const child = token.children[0];
|
const child = token.children[0];
|
||||||
let text = child.type === 'text' ? child.props.text : '';
|
let text = child.type === 'text' ? child.props.text : '';
|
||||||
if (!disableNyaize && shouldNyaize) {
|
if (!disableNyaize && shouldNyaize) {
|
||||||
text = doNyaize(text);
|
text = Misskey.nyaize(text);
|
||||||
}
|
}
|
||||||
return h('ruby', {}, [text.split(' ')[0], h('rt', text.split(' ')[1])]);
|
return h('ruby', {}, [text.split(' ')[0], h('rt', text.split(' ')[1])]);
|
||||||
} else {
|
} else {
|
||||||
const rt = token.children.at(-1)!;
|
const rt = token.children.at(-1)!;
|
||||||
let text = rt.type === 'text' ? rt.props.text : '';
|
let text = rt.type === 'text' ? rt.props.text : '';
|
||||||
if (!disableNyaize && shouldNyaize) {
|
if (!disableNyaize && shouldNyaize) {
|
||||||
text = doNyaize(text);
|
text = Misskey.nyaize(text);
|
||||||
}
|
}
|
||||||
return h('ruby', {}, [...genEl(token.children.slice(0, token.children.length - 1), scale), h('rt', text.trim())]);
|
return h('ruby', {}, [...genEl(token.children.slice(0, token.children.length - 1), scale), h('rt', text.trim())]);
|
||||||
}
|
}
|
||||||
|
@ -4,13 +4,13 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
import { utils, values } from '@syuilo/aiscript';
|
import { utils, values } from '@syuilo/aiscript';
|
||||||
|
import * as Misskey from 'misskey-js';
|
||||||
import * as os from '@/os.js';
|
import * as os from '@/os.js';
|
||||||
import { misskeyApi } from '@/scripts/misskey-api.js';
|
import { misskeyApi } from '@/scripts/misskey-api.js';
|
||||||
import { $i } from '@/account.js';
|
import { $i } from '@/account.js';
|
||||||
import { miLocalStorage } from '@/local-storage.js';
|
import { miLocalStorage } from '@/local-storage.js';
|
||||||
import { customEmojis } from '@/custom-emojis.js';
|
import { customEmojis } from '@/custom-emojis.js';
|
||||||
import { url, lang } from '@/config.js';
|
import { url, lang } from '@/config.js';
|
||||||
import { nyaize } from '@/scripts/nyaize.js';
|
|
||||||
|
|
||||||
export function aiScriptReadline(q: string): Promise<string> {
|
export function aiScriptReadline(q: string): Promise<string> {
|
||||||
return new Promise(ok => {
|
return new Promise(ok => {
|
||||||
@ -87,7 +87,7 @@ export function createAiScriptEnv(opts) {
|
|||||||
}),
|
}),
|
||||||
'Mk:nyaize': values.FN_NATIVE(([text]) => {
|
'Mk:nyaize': values.FN_NATIVE(([text]) => {
|
||||||
utils.assertString(text);
|
utils.assertString(text);
|
||||||
return values.STR(nyaize(text.value));
|
return values.STR(Misskey.nyaize(text.value));
|
||||||
}),
|
}),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -1,27 +0,0 @@
|
|||||||
/*
|
|
||||||
* SPDX-FileCopyrightText: syuilo and misskey-project
|
|
||||||
* SPDX-License-Identifier: AGPL-3.0-only
|
|
||||||
*/
|
|
||||||
|
|
||||||
const enRegex1 = /(?<=n)a/gi;
|
|
||||||
const enRegex2 = /(?<=morn)ing/gi;
|
|
||||||
const enRegex3 = /(?<=every)one/gi;
|
|
||||||
const koRegex1 = /[나-낳]/g;
|
|
||||||
const koRegex2 = /(다$)|(다(?=\.))|(다(?= ))|(다(?=!))|(다(?=\?))/gm;
|
|
||||||
const koRegex3 = /(야(?=\?))|(야$)|(야(?= ))/gm;
|
|
||||||
|
|
||||||
export function nyaize(text: string): string {
|
|
||||||
return text
|
|
||||||
// ja-JP
|
|
||||||
.replaceAll('な', 'にゃ').replaceAll('ナ', 'ニャ').replaceAll('ナ', 'ニャ')
|
|
||||||
// en-US
|
|
||||||
.replace(enRegex1, x => x === 'A' ? 'YA' : 'ya')
|
|
||||||
.replace(enRegex2, x => x === 'ING' ? 'YAN' : 'yan')
|
|
||||||
.replace(enRegex3, x => x === 'ONE' ? 'NYAN' : 'nyan')
|
|
||||||
// ko-KR
|
|
||||||
.replace(koRegex1, match => String.fromCharCode(
|
|
||||||
match.charCodeAt(0)! + '냐'.charCodeAt(0) - '나'.charCodeAt(0),
|
|
||||||
))
|
|
||||||
.replace(koRegex2, '다냥')
|
|
||||||
.replace(koRegex3, '냥');
|
|
||||||
}
|
|
@ -22,7 +22,8 @@ import * as api from './api.js';
|
|||||||
import * as entities from './entities.js';
|
import * as entities from './entities.js';
|
||||||
import * as acct from './acct.js';
|
import * as acct from './acct.js';
|
||||||
import * as note from './note.js';
|
import * as note from './note.js';
|
||||||
export { api, entities, acct, note };
|
import { nyaize } from './nyaize.js';
|
||||||
|
export { api, entities, acct, note, nyaize };
|
||||||
|
|
||||||
//#region standalone types
|
//#region standalone types
|
||||||
import type { Endpoints } from './api.types.js';
|
import type { Endpoints } from './api.types.js';
|
||||||
|
Loading…
Reference in New Issue
Block a user