mirror of
https://git.joinsharkey.org/Sharkey/Sharkey.git
synced 2025-01-23 20:43:08 +02:00
parent
c05c504c86
commit
42833cd921
3 changed files with 34 additions and 3 deletions
|
@ -75,6 +75,8 @@ import MkPagination from '@/components/MkPagination.vue';
|
||||||
import MkPagePreview from '@/components/MkPagePreview.vue';
|
import MkPagePreview from '@/components/MkPagePreview.vue';
|
||||||
import { i18n } from '@/i18n';
|
import { i18n } from '@/i18n';
|
||||||
import { definePageMetadata } from '@/scripts/page-metadata';
|
import { definePageMetadata } from '@/scripts/page-metadata';
|
||||||
|
import { pageViewInterruptors } from '@/store';
|
||||||
|
import { deepClone } from '@/scripts/clone';
|
||||||
|
|
||||||
const props = defineProps<{
|
const props = defineProps<{
|
||||||
pageName: string;
|
pageName: string;
|
||||||
|
@ -97,8 +99,17 @@ function fetchPage() {
|
||||||
os.api('pages/show', {
|
os.api('pages/show', {
|
||||||
name: props.pageName,
|
name: props.pageName,
|
||||||
username: props.username,
|
username: props.username,
|
||||||
}).then(_page => {
|
}).then(async _page => {
|
||||||
page = _page;
|
page = _page;
|
||||||
|
|
||||||
|
// plugin
|
||||||
|
if (pageViewInterruptors.length > 0) {
|
||||||
|
let result = deepClone(_page);
|
||||||
|
for (const interruptor of pageViewInterruptors) {
|
||||||
|
result = await interruptor.handler(result);
|
||||||
|
}
|
||||||
|
page = result;
|
||||||
|
}
|
||||||
}).catch(err => {
|
}).catch(err => {
|
||||||
error = err;
|
error = err;
|
||||||
});
|
});
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import { Interpreter, Parser, utils, values } from '@syuilo/aiscript';
|
import { Interpreter, Parser, utils, values } from '@syuilo/aiscript';
|
||||||
import { createAiScriptEnv } from '@/scripts/aiscript/api';
|
import { createAiScriptEnv } from '@/scripts/aiscript/api';
|
||||||
import { inputText } from '@/os';
|
import { inputText } from '@/os';
|
||||||
import { Plugin, noteActions, notePostInterruptors, noteViewInterruptors, postFormActions, userActions } from '@/store';
|
import { Plugin, noteActions, notePostInterruptors, noteViewInterruptors, postFormActions, userActions, pageViewInterruptors } from '@/store';
|
||||||
|
|
||||||
const parser = new Parser();
|
const parser = new Parser();
|
||||||
const pluginContexts = new Map<string, Interpreter>();
|
const pluginContexts = new Map<string, Interpreter>();
|
||||||
|
@ -80,6 +80,9 @@ function createPluginEnv(opts: { plugin: Plugin; storageKey: string }): Record<s
|
||||||
'Plugin:register_note_post_interruptor': values.FN_NATIVE(([handler]) => {
|
'Plugin:register_note_post_interruptor': values.FN_NATIVE(([handler]) => {
|
||||||
registerNotePostInterruptor({ pluginId: opts.plugin.id, handler });
|
registerNotePostInterruptor({ pluginId: opts.plugin.id, handler });
|
||||||
}),
|
}),
|
||||||
|
'Plugin:register_page_view_interruptor': values.FN_NATIVE(([handler]) => {
|
||||||
|
registerPageViewInterruptor({ pluginId: opts.plugin.id, handler });
|
||||||
|
}),
|
||||||
'Plugin:open_url': values.FN_NATIVE(([url]) => {
|
'Plugin:open_url': values.FN_NATIVE(([url]) => {
|
||||||
utils.assertString(url);
|
utils.assertString(url);
|
||||||
window.open(url.value, '_blank');
|
window.open(url.value, '_blank');
|
||||||
|
@ -156,3 +159,15 @@ function registerNotePostInterruptor({ pluginId, handler }): void {
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function registerPageViewInterruptor({ pluginId, handler }): void {
|
||||||
|
pageViewInterruptors.push({
|
||||||
|
handler: async (page) => {
|
||||||
|
const pluginContext = pluginContexts.get(pluginId);
|
||||||
|
if (!pluginContext) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
return utils.valToJs(await pluginContext.execFn(handler, [utils.jsToVal(page)]));
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
|
@ -24,11 +24,16 @@ interface NotePostInterruptor {
|
||||||
handler: (note: FIXME) => unknown;
|
handler: (note: FIXME) => unknown;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
interface PageViewInterruptor {
|
||||||
|
handler: (page: Page) => unknown;
|
||||||
|
}
|
||||||
|
|
||||||
export const postFormActions: PostFormAction[] = [];
|
export const postFormActions: PostFormAction[] = [];
|
||||||
export const userActions: UserAction[] = [];
|
export const userActions: UserAction[] = [];
|
||||||
export const noteActions: NoteAction[] = [];
|
export const noteActions: NoteAction[] = [];
|
||||||
export const noteViewInterruptors: NoteViewInterruptor[] = [];
|
export const noteViewInterruptors: NoteViewInterruptor[] = [];
|
||||||
export const notePostInterruptors: NotePostInterruptor[] = [];
|
export const notePostInterruptors: NotePostInterruptor[] = [];
|
||||||
|
export const pageViewInterruptors: PageViewInterruptor[] = [];
|
||||||
|
|
||||||
// TODO: それぞれいちいちwhereとかdefaultというキーを付けなきゃいけないの冗長なのでなんとかする(ただ型定義が面倒になりそう)
|
// TODO: それぞれいちいちwhereとかdefaultというキーを付けなきゃいけないの冗長なのでなんとかする(ただ型定義が面倒になりそう)
|
||||||
// あと、現行の定義の仕方なら「whereが何であるかに関わらずキー名の重複不可」という制約を付けられるメリットもあるからそのメリットを引き継ぐ方法も考えないといけない
|
// あと、現行の定義の仕方なら「whereが何であるかに関わらずキー名の重複不可」という制約を付けられるメリットもあるからそのメリットを引き継ぐ方法も考えないといけない
|
||||||
|
@ -318,7 +323,7 @@ interface Watcher {
|
||||||
import { miLocalStorage } from './local-storage';
|
import { miLocalStorage } from './local-storage';
|
||||||
import lightTheme from '@/themes/l-light.json5';
|
import lightTheme from '@/themes/l-light.json5';
|
||||||
import darkTheme from '@/themes/d-green-lime.json5';
|
import darkTheme from '@/themes/d-green-lime.json5';
|
||||||
import { Note, UserDetailed } from 'misskey-js/built/entities';
|
import { Note, UserDetailed, Page } from 'misskey-js/built/entities';
|
||||||
|
|
||||||
export class ColdDeviceStorage {
|
export class ColdDeviceStorage {
|
||||||
public static default = {
|
public static default = {
|
||||||
|
|
Loading…
Reference in a new issue