Merge branch 'develop' into better-tutorial
This commit is contained in:
commit
4140b6011e
|
@ -39,6 +39,7 @@
|
||||||
- Enhance: プラグインを削除した際には、使用されていたアクセストークンも同時に削除されるようになりました
|
- Enhance: プラグインを削除した際には、使用されていたアクセストークンも同時に削除されるようになりました
|
||||||
- Enhance: プラグインで`Plugin:register_note_view_interruptor`を用いてnoteの代わりにnullを返却することでノートを非表示にできるようになりました
|
- Enhance: プラグインで`Plugin:register_note_view_interruptor`を用いてnoteの代わりにnullを返却することでノートを非表示にできるようになりました
|
||||||
- Enhance: AiScript関数`Mk:nyaize()`が追加されました
|
- Enhance: AiScript関数`Mk:nyaize()`が追加されました
|
||||||
|
- Enhance: 情報→ツール はナビゲーションバーにツールとして独立した項目になりました
|
||||||
- Enhance: その他細かなブラッシュアップ
|
- Enhance: その他細かなブラッシュアップ
|
||||||
- Fix: 投稿フォームでのユーザー変更がプレビューに反映されない問題を修正
|
- Fix: 投稿フォームでのユーザー変更がプレビューに反映されない問題を修正
|
||||||
- Fix: ユーザーページの ノート > ファイル付き タブにリプライが表示されてしまう
|
- Fix: ユーザーページの ノート > ファイル付き タブにリプライが表示されてしまう
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
import { computed, reactive } from 'vue';
|
import { computed, reactive } from 'vue';
|
||||||
import { $i } from '@/account.js';
|
import { $i } from '@/account.js';
|
||||||
import { miLocalStorage } from '@/local-storage.js';
|
import { miLocalStorage } from '@/local-storage.js';
|
||||||
import { openInstanceMenu } from '@/ui/_common_/common.js';
|
import { openInstanceMenu, openToolsMenu } from '@/ui/_common_/common.js';
|
||||||
import { lookup } from '@/scripts/lookup.js';
|
import { lookup } from '@/scripts/lookup.js';
|
||||||
import * as os from '@/os.js';
|
import * as os from '@/os.js';
|
||||||
import { i18n } from '@/i18n.js';
|
import { i18n } from '@/i18n.js';
|
||||||
|
@ -142,6 +142,13 @@ export const navbarItemDef = reactive({
|
||||||
openInstanceMenu(ev);
|
openInstanceMenu(ev);
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
tools: {
|
||||||
|
title: i18n.ts.tools,
|
||||||
|
icon: 'ti ti-tool',
|
||||||
|
action: (ev) => {
|
||||||
|
openToolsMenu(ev);
|
||||||
|
},
|
||||||
|
},
|
||||||
reload: {
|
reload: {
|
||||||
title: i18n.ts.reload,
|
title: i18n.ts.reload,
|
||||||
icon: 'ti ti-refresh',
|
icon: 'ti ti-refresh',
|
||||||
|
|
|
@ -148,36 +148,42 @@ function closeTutorial(): void {
|
||||||
defaultStore.set('timelineTutorials', before);
|
defaultStore.set('timelineTutorials', before);
|
||||||
}
|
}
|
||||||
|
|
||||||
const headerActions = $computed(() => [
|
const headerActions = $computed(() => {
|
||||||
...[deviceKind === 'desktop' ? {
|
const tmp = [
|
||||||
icon: 'ti ti-refresh',
|
{
|
||||||
text: i18n.ts.reload,
|
icon: 'ti ti-dots',
|
||||||
handler: (ev) => {
|
text: i18n.ts.options,
|
||||||
console.log('called');
|
handler: (ev) => {
|
||||||
tlComponent.reloadTimeline();
|
os.popupMenu([{
|
||||||
|
type: 'switch',
|
||||||
|
text: i18n.ts.showRenotes,
|
||||||
|
icon: 'ti ti-repeat',
|
||||||
|
ref: $$(withRenotes),
|
||||||
|
}, src === 'local' || src === 'social' ? {
|
||||||
|
type: 'switch',
|
||||||
|
text: i18n.ts.showRepliesToOthersInTimeline,
|
||||||
|
ref: $$(withReplies),
|
||||||
|
} : undefined, {
|
||||||
|
type: 'switch',
|
||||||
|
text: i18n.ts.fileAttachedOnly,
|
||||||
|
icon: 'ti ti-photo',
|
||||||
|
ref: $$(onlyFiles),
|
||||||
|
}], ev.currentTarget ?? ev.target);
|
||||||
|
},
|
||||||
},
|
},
|
||||||
} : {}], {
|
];
|
||||||
icon: 'ti ti-dots',
|
if (deviceKind === 'desktop') {
|
||||||
text: i18n.ts.options,
|
tmp.unshift({
|
||||||
handler: (ev) => {
|
icon: 'ti ti-refresh',
|
||||||
os.popupMenu([{
|
text: i18n.ts.reload,
|
||||||
type: 'switch',
|
handler: (ev: Event) => {
|
||||||
text: i18n.ts.showRenotes,
|
console.log('called');
|
||||||
icon: 'ti ti-repeat',
|
tlComponent.reloadTimeline();
|
||||||
ref: $$(withRenotes),
|
},
|
||||||
}, src === 'local' || src === 'social' ? {
|
});
|
||||||
type: 'switch',
|
}
|
||||||
text: i18n.ts.showRepliesToOthersInTimeline,
|
return tmp;
|
||||||
ref: $$(withReplies),
|
});
|
||||||
} : undefined, {
|
|
||||||
type: 'switch',
|
|
||||||
text: i18n.ts.fileAttachedOnly,
|
|
||||||
icon: 'ti ti-photo',
|
|
||||||
ref: $$(onlyFiles),
|
|
||||||
}], ev.currentTarget ?? ev.target);
|
|
||||||
},
|
|
||||||
},
|
|
||||||
]);
|
|
||||||
|
|
||||||
const headerTabs = $computed(() => [...(defaultStore.reactiveState.pinnedUserLists.value.map(l => ({
|
const headerTabs = $computed(() => [...(defaultStore.reactiveState.pinnedUserLists.value.map(l => ({
|
||||||
key: 'list:' + l.id,
|
key: 'list:' + l.id,
|
||||||
|
|
|
@ -4,12 +4,42 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import { defineAsyncComponent } from 'vue';
|
import { defineAsyncComponent } from 'vue';
|
||||||
|
import type { MenuItem } from '@/types/menu.js';
|
||||||
import * as os from '@/os.js';
|
import * as os from '@/os.js';
|
||||||
import { instance } from '@/instance.js';
|
import { instance } from '@/instance.js';
|
||||||
import { host } from '@/config.js';
|
import { host } from '@/config.js';
|
||||||
import { i18n } from '@/i18n.js';
|
import { i18n } from '@/i18n.js';
|
||||||
import { $i } from '@/account.js';
|
import { $i } from '@/account.js';
|
||||||
|
|
||||||
|
function toolsMenuItems(): MenuItem[] {
|
||||||
|
return [{
|
||||||
|
type: 'link',
|
||||||
|
to: '/scratchpad',
|
||||||
|
text: i18n.ts.scratchpad,
|
||||||
|
icon: 'ti ti-terminal-2',
|
||||||
|
}, {
|
||||||
|
type: 'link',
|
||||||
|
to: '/api-console',
|
||||||
|
text: 'API Console',
|
||||||
|
icon: 'ti ti-terminal-2',
|
||||||
|
}, {
|
||||||
|
type: 'link',
|
||||||
|
to: '/clicker',
|
||||||
|
text: '🍪👈',
|
||||||
|
icon: 'ti ti-cookie',
|
||||||
|
}, ($i && ($i.isAdmin || $i.policies.canManageCustomEmojis)) ? {
|
||||||
|
type: 'link',
|
||||||
|
to: '/custom-emojis-manager',
|
||||||
|
text: i18n.ts.manageCustomEmojis,
|
||||||
|
icon: 'ti ti-icons',
|
||||||
|
} : undefined, ($i && ($i.isAdmin || $i.policies.canManageAvatarDecorations)) ? {
|
||||||
|
type: 'link',
|
||||||
|
to: '/avatar-decorations',
|
||||||
|
text: i18n.ts.manageAvatarDecorations,
|
||||||
|
icon: 'ti ti-sparkles',
|
||||||
|
} : undefined];
|
||||||
|
}
|
||||||
|
|
||||||
export function openInstanceMenu(ev: MouseEvent) {
|
export function openInstanceMenu(ev: MouseEvent) {
|
||||||
os.popupMenu([{
|
os.popupMenu([{
|
||||||
text: instance.name ?? host,
|
text: instance.name ?? host,
|
||||||
|
@ -48,32 +78,7 @@ export function openInstanceMenu(ev: MouseEvent) {
|
||||||
type: 'parent',
|
type: 'parent',
|
||||||
text: i18n.ts.tools,
|
text: i18n.ts.tools,
|
||||||
icon: 'ti ti-tool',
|
icon: 'ti ti-tool',
|
||||||
children: [{
|
children: toolsMenuItems(),
|
||||||
type: 'link',
|
|
||||||
to: '/scratchpad',
|
|
||||||
text: i18n.ts.scratchpad,
|
|
||||||
icon: 'ti ti-terminal-2',
|
|
||||||
}, {
|
|
||||||
type: 'link',
|
|
||||||
to: '/api-console',
|
|
||||||
text: 'API Console',
|
|
||||||
icon: 'ti ti-terminal-2',
|
|
||||||
}, {
|
|
||||||
type: 'link',
|
|
||||||
to: '/clicker',
|
|
||||||
text: '🍪👈',
|
|
||||||
icon: 'ti ti-cookie',
|
|
||||||
}, ($i && ($i.isAdmin || $i.policies.canManageCustomEmojis)) ? {
|
|
||||||
type: 'link',
|
|
||||||
to: '/custom-emojis-manager',
|
|
||||||
text: i18n.ts.manageCustomEmojis,
|
|
||||||
icon: 'ti ti-icons',
|
|
||||||
} : undefined, ($i && ($i.isAdmin || $i.policies.canManageAvatarDecorations)) ? {
|
|
||||||
type: 'link',
|
|
||||||
to: '/avatar-decorations',
|
|
||||||
text: i18n.ts.manageAvatarDecorations,
|
|
||||||
icon: 'ti ti-sparkles',
|
|
||||||
} : undefined],
|
|
||||||
}, null, (instance.impressumUrl) ? {
|
}, null, (instance.impressumUrl) ? {
|
||||||
text: i18n.ts.impressum,
|
text: i18n.ts.impressum,
|
||||||
icon: 'ti ti-file-invoice',
|
icon: 'ti ti-file-invoice',
|
||||||
|
@ -112,3 +117,9 @@ export function openInstanceMenu(ev: MouseEvent) {
|
||||||
align: 'left',
|
align: 'left',
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export function openToolsMenu(ev: MouseEvent) {
|
||||||
|
os.popupMenu(toolsMenuItems(), ev.currentTarget ?? ev.target, {
|
||||||
|
align: 'left',
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue