/* eslint-disable @typescript-eslint/explicit-function-return-type */
import { StoryObj } from '@storybook/vue3';
import { userDetailed } from '../../../.storybook/fakes';
import MkAvatar from './MkAvatar.vue';
const common = {
render(args) {
return {
components: {
MkAvatar,
},
setup() {
args,
};
computed: {
props() {
...this.args,
template: '<MkAvatar v-bind="props" />',
args: {
user: userDetailed(),
decorators: [
(Story, context) => ({
// eslint-disable-next-line quotes
template: `<div :style="{ display: 'grid', width: '${context.args.size}px', height: '${context.args.size}px' }"><story/></div>`,
}),
],
parameters: {
layout: 'centered',
} satisfies StoryObj<typeof MkAvatar>;
export const ProfilePage = {
...common,
...common.args,
size: 120,
indicator: true,
export const ProfilePageCat = {
...ProfilePage,
...ProfilePage.args,
user: {
...userDetailed(),
isCat: true,
...ProfilePage.parameters,
chromatic: {
/* Your story couldn’t be captured because it exceeds our 25,000,000px limit. Its dimensions are 5,504,893x5,504,892px. Possible ways to resolve:
* * Separate pages into components
* * Minimize the number of very large elements in a story
*/
disableSnapshot: true,