/* * SPDX-FileCopyrightText: syuilo and misskey-project * SPDX-License-Identifier: AGPL-3.0-only */ /* eslint-disable @typescript-eslint/explicit-function-return-type */ /* eslint-disable import/no-default-export */ import { StoryObj } from '@storybook/vue3'; import { http } from 'msw'; import { commonHandlers } from '../../.storybook/mocks.js'; import { getChartResolver } from '../../.storybook/charts.js'; import MkChart from './MkChart.vue'; const Base = { render(args) { return { components: { MkChart, }, setup() { return { args, }; }, computed: { props() { return { ...this.args, }; }, }, template: '', }; }, args: { src: 'federation', span: 'hour', nowForChromatic: 1716263640000, }, parameters: { layout: 'centered', msw: { handlers: [ ...commonHandlers, http.get('/api/charts/federation', getChartResolver( ['deliveredInstances', 'inboxInstances', 'stalled', 'sub', 'pub', 'pubsub', 'subActive', 'pubActive'], )), http.get('/api/charts/notes', getChartResolver( ['local.total', 'remote.total'], { accumulate: true }, )), http.get('/api/charts/drive', getChartResolver( ['local.incSize', 'local.decSize', 'remote.incSize', 'remote.decSize'], { mulMap: { 'local.incSize': 1e7, 'local.decSize': 5e6, 'remote.incSize': 1e6, 'remote.decSize': 5e5 } }, )), ], }, }, } satisfies StoryObj; export const FederationChart = { ...Base, args: { ...Base.args, src: 'federation', }, } satisfies StoryObj; export const NotesTotalChart = { ...Base, args: { ...Base.args, src: 'notes-total', }, } satisfies StoryObj; export const DriveChart = { ...Base, args: { ...Base.args, src: 'drive', }, } satisfies StoryObj;