summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authortamaina <tamaina@hotmail.co.jp>2022-02-04 08:39:20 +0900
committerGitHub <noreply@github.com>2022-02-04 08:39:20 +0900
commitd31945e1fd692ce657e18cf7349e89bef5f46d0e (patch)
tree4ba0faacb83947d79fc01d174ea388406bb12108
parentrefactor (diff)
downloadsharkey-d31945e1fd692ce657e18cf7349e89bef5f46d0e.tar.gz
sharkey-d31945e1fd692ce657e18cf7349e89bef5f46d0e.tar.bz2
sharkey-d31945e1fd692ce657e18cf7349e89bef5f46d0e.zip
fix: タイムライン種別を切り替えると「新しいノートがあります」の表示が残留してしまうのを修正 (#8250)
Fix #6831
-rw-r--r--packages/client/src/pages/timeline.vue23
1 files changed, 13 insertions, 10 deletions
diff --git a/packages/client/src/pages/timeline.vue b/packages/client/src/pages/timeline.vue
index b2266d22c3..79f00c4b44 100644
--- a/packages/client/src/pages/timeline.vue
+++ b/packages/client/src/pages/timeline.vue
@@ -46,8 +46,10 @@ const keymap = {
const tlComponent = $ref<InstanceType<typeof XTimeline>>();
const rootEl = $ref<HTMLElement>();
-let src = $ref<'home' | 'local' | 'social' | 'global'>(defaultStore.state.tl.src);
let queue = $ref(0);
+const src = $computed(() => defaultStore.reactiveState.tl.value.src);
+
+watch ($$(src), () => queue = 0);
function queueUpdated(q: number): void {
queue = q;
@@ -60,7 +62,7 @@ function top(): void {
async function chooseList(ev: MouseEvent): Promise<void> {
const lists = await os.api('users/lists/list');
const items = lists.map(list => ({
- type: 'link',
+ type: 'link' as const,
text: list.name,
to: `/timeline/list/${list.id}`,
}));
@@ -70,7 +72,7 @@ async function chooseList(ev: MouseEvent): Promise<void> {
async function chooseAntenna(ev: MouseEvent): Promise<void> {
const antennas = await os.api('antennas/list');
const items = antennas.map(antenna => ({
- type: 'link',
+ type: 'link' as const,
text: antenna.name,
indicate: antenna.hasUnreadNote,
to: `/timeline/antenna/${antenna.id}`,
@@ -81,7 +83,7 @@ async function chooseAntenna(ev: MouseEvent): Promise<void> {
async function chooseChannel(ev: MouseEvent): Promise<void> {
const channels = await os.api('channels/followed');
const items = channels.map(channel => ({
- type: 'link',
+ type: 'link' as const,
text: channel.name,
indicate: channel.hasUnreadNote,
to: `/channels/${channel.id}`,
@@ -89,9 +91,10 @@ async function chooseChannel(ev: MouseEvent): Promise<void> {
os.popupMenu(items, ev.currentTarget ?? ev.target);
}
-function saveSrc(): void {
+function saveSrc(newSrc: 'home' | 'local' | 'social' | 'global'): void {
defaultStore.set('tl', {
- src: src,
+ ...defaultStore.state.tl,
+ src: newSrc,
});
}
@@ -135,25 +138,25 @@ defineExpose({
title: i18n.ts._timelines.home,
icon: 'fas fa-home',
iconOnly: true,
- onClick: () => { src = 'home'; saveSrc(); },
+ onClick: () => { saveSrc('home'); },
}, ...(isLocalTimelineAvailable ? [{
active: src === 'local',
title: i18n.ts._timelines.local,
icon: 'fas fa-comments',
iconOnly: true,
- onClick: () => { src = 'local'; saveSrc(); },
+ onClick: () => { saveSrc('local'); },
}, {
active: src === 'social',
title: i18n.ts._timelines.social,
icon: 'fas fa-share-alt',
iconOnly: true,
- onClick: () => { src = 'social'; saveSrc(); },
+ onClick: () => { saveSrc('social'); },
}] : []), ...(isGlobalTimelineAvailable ? [{
active: src === 'global',
title: i18n.ts._timelines.global,
icon: 'fas fa-globe',
iconOnly: true,
- onClick: () => { src = 'global'; saveSrc(); },
+ onClick: () => { saveSrc('global'); },
}] : [])],
})),
});