mirror of
https://github.com/misskey-dev/misskey.git
synced 2025-01-01 02:46:20 +01:00
[Story]MkNote
This commit is contained in:
parent
57effa9ef0
commit
502657235c
2 changed files with 219 additions and 0 deletions
|
@ -207,12 +207,71 @@ export function note(id = 'somenoteid'): entities.Note {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export function remoteNote(id = 'somenoteId'){
|
||||||
|
return {
|
||||||
|
...note(),
|
||||||
|
user: {
|
||||||
|
...userLite(id, "remoteUser", "Remote Server"),
|
||||||
|
},
|
||||||
|
text: "this is remote note text"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export function renotedNote(id = 'somenoteId'): entities.Note {
|
||||||
|
return {
|
||||||
|
...note(id),
|
||||||
|
renote: {...note()},
|
||||||
|
text: null,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export function quotedNote(id = 'somenoteId'): entities.Note {
|
||||||
|
return {
|
||||||
|
...note(id),
|
||||||
|
renote: {...note()},
|
||||||
|
text: "quote note"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export function channelNote(id = 'somenoteId'): entities.Note {
|
||||||
|
return {
|
||||||
|
...note(id),
|
||||||
|
channel: channel(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// チャンネルからのRenoteは renote に channnelNoteを入れる
|
||||||
|
export function renotedFromChannelnote(id = "somenoteId"){
|
||||||
|
return {
|
||||||
|
...note(id),
|
||||||
|
renote: channelNote(),
|
||||||
|
text: null
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// チャンネルへRenoteされたTLのNoteは renoteにnoteを入れる ベースはchannelNoteである
|
||||||
|
export function renotedToChannel(id = "somenoteId"){
|
||||||
|
return {
|
||||||
|
...channelNote(),
|
||||||
|
renote: note(),
|
||||||
|
text: null
|
||||||
|
}
|
||||||
|
}
|
||||||
|
export function renotedToChannelFromChannel(id = "somenoteId"){
|
||||||
|
return {
|
||||||
|
...channelNote(),
|
||||||
|
renote: channelNote(),
|
||||||
|
text: null
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
export function userLite(id = 'someuserid', username = 'miskist', host: entities.UserDetailed['host'] = 'misskey-hub.net', name: entities.UserDetailed['name'] = 'Misskey User'): entities.UserLite {
|
export function userLite(id = 'someuserid', username = 'miskist', host: entities.UserDetailed['host'] = 'misskey-hub.net', name: entities.UserDetailed['name'] = 'Misskey User'): entities.UserLite {
|
||||||
return {
|
return {
|
||||||
id,
|
id,
|
||||||
username,
|
username,
|
||||||
host,
|
host,
|
||||||
name,
|
name,
|
||||||
|
instance: host !== 'misskey-hub.net' ? federationInstance() : null,
|
||||||
onlineStatus: 'unknown',
|
onlineStatus: 'unknown',
|
||||||
avatarUrl: 'https://github.com/misskey-dev/misskey/blob/master/packages/frontend/assets/about-icon.png?raw=true',
|
avatarUrl: 'https://github.com/misskey-dev/misskey/blob/master/packages/frontend/assets/about-icon.png?raw=true',
|
||||||
avatarBlurhash: 'eQFRshof5NWBRi},juayfPju53WB?0ofs;s*a{ofjuay^SoMEJR%ay',
|
avatarBlurhash: 'eQFRshof5NWBRi},juayfPju53WB?0ofs;s*a{ofjuay^SoMEJR%ay',
|
||||||
|
|
160
packages/frontend/src/components/MkNote.stories.ts
Normal file
160
packages/frontend/src/components/MkNote.stories.ts
Normal file
|
@ -0,0 +1,160 @@
|
||||||
|
/* eslint-disable @typescript-eslint/explicit-function-return-type */
|
||||||
|
/* eslint-disable import/no-default-export */
|
||||||
|
/* eslint-disable import/no-duplicates */
|
||||||
|
/* eslint-disable import/order */
|
||||||
|
import { Meta } from '@storybook/vue3';
|
||||||
|
const meta = {
|
||||||
|
title: 'components/MkNote',
|
||||||
|
component: MkNote,
|
||||||
|
} satisfies Meta<typeof MkNote>;
|
||||||
|
export default meta;
|
||||||
|
/*
|
||||||
|
* SPDX-FileCopyrightText: syuilo and misskey-project
|
||||||
|
* SPDX-License-Identifier: AGPL-3.0-only
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* eslint-disable @typescript-eslint/explicit-function-return-type */
|
||||||
|
import { StoryObj } from '@storybook/vue3';
|
||||||
|
import { HttpResponse, http } from 'msw';
|
||||||
|
import {
|
||||||
|
note,
|
||||||
|
channel,
|
||||||
|
channelNote,
|
||||||
|
quotedNote,
|
||||||
|
renotedNote,
|
||||||
|
remoteNote,
|
||||||
|
renotedFromChannelnote, renotedToChannel, renotedToChannelFromChannel
|
||||||
|
} from '../../.storybook/fakes.js';
|
||||||
|
import { commonHandlers } from '../../.storybook/mocks.js';
|
||||||
|
import MkNote from "@/components/MkNote.vue";
|
||||||
|
|
||||||
|
|
||||||
|
export const Default = {
|
||||||
|
render(args) {
|
||||||
|
return {
|
||||||
|
components: {
|
||||||
|
MkNote,
|
||||||
|
},
|
||||||
|
setup() {
|
||||||
|
return {
|
||||||
|
args,
|
||||||
|
};
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
props() {
|
||||||
|
return {
|
||||||
|
...this.args,
|
||||||
|
};
|
||||||
|
},
|
||||||
|
},
|
||||||
|
template: '<MkNote v-bind="props" />',
|
||||||
|
};
|
||||||
|
},
|
||||||
|
args: {
|
||||||
|
note: note(),
|
||||||
|
},
|
||||||
|
parameters: {
|
||||||
|
layout: 'centered',
|
||||||
|
msw: {
|
||||||
|
handlers: [
|
||||||
|
...commonHandlers,
|
||||||
|
http.get('/undefined/preview.webp', async ({ request }) => {
|
||||||
|
const urlStr = new URL(request.url).searchParams.get('url');
|
||||||
|
if (urlStr == null) {
|
||||||
|
return new HttpResponse(null, { status: 404 });
|
||||||
|
}
|
||||||
|
const url = new URL(urlStr);
|
||||||
|
|
||||||
|
if (
|
||||||
|
url.href.startsWith(
|
||||||
|
'https://github.com/misskey-dev/misskey/blob/master/packages/frontend/assets/',
|
||||||
|
)
|
||||||
|
) {
|
||||||
|
const image = await (
|
||||||
|
await fetch(`client-assets/${url.pathname.split('/').pop()}`)
|
||||||
|
).blob();
|
||||||
|
return new HttpResponse(image, {
|
||||||
|
headers: {
|
||||||
|
'Content-Type': 'image/jpeg',
|
||||||
|
},
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
return new HttpResponse(null, { status: 404 });
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
} satisfies StoryObj<typeof MkNote>;
|
||||||
|
|
||||||
|
export const Channel = {
|
||||||
|
...Default,
|
||||||
|
args: {
|
||||||
|
note: channelNote()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export const Quoted = {
|
||||||
|
...Default,
|
||||||
|
args: {
|
||||||
|
note: quotedNote()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export const Renoted = {
|
||||||
|
...Default,
|
||||||
|
args: {
|
||||||
|
note: renotedNote()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export const RemoteNote = {
|
||||||
|
...Default,
|
||||||
|
args: {
|
||||||
|
note: remoteNote(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export const Renote_RemoteNote = {
|
||||||
|
...Default,
|
||||||
|
args: {
|
||||||
|
note: {
|
||||||
|
...note(),
|
||||||
|
renote: remoteNote(),
|
||||||
|
text: null
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export const RemoteuserRenoteNote = {
|
||||||
|
...Default,
|
||||||
|
args: {
|
||||||
|
note: {
|
||||||
|
...remoteNote(),
|
||||||
|
renote: note(),
|
||||||
|
text: null
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export const RenotedFromChannel = {
|
||||||
|
...Default,
|
||||||
|
args: {
|
||||||
|
note: renotedFromChannelnote()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export const RenotedToChannel = {
|
||||||
|
...Default,
|
||||||
|
args: {
|
||||||
|
note: renotedToChannel()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export const RenotedToChannelFromChannel = {
|
||||||
|
...Default,
|
||||||
|
args: {
|
||||||
|
note: renotedToChannelFromChannel()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue