vueless
Version:
Vue Styleless UI Component Library, powered by Tailwind CSS.
111 lines (97 loc) • 2.75 kB
text/typescript
import {
getArgs,
getArgTypes,
getSlotNames,
getSlotsFragment,
getDocsDescription,
} from "../../utils/storybook.ts";
import UEmpty from "../../ui.text-empty/UEmpty.vue";
import UButton from "../../ui.button/UButton.vue";
import UIcon from "../../ui.image-icon/UIcon.vue";
import URow from "../../ui.container-row/URow.vue";
import UBadge from "../../ui.text-badge/UBadge.vue";
import ULink from "../../ui.button-link/ULink.vue";
import UText from "../../ui.text-block/UText.vue";
import emptyInbox from "./assets/empty-inbox.png";
import type { Meta, StoryFn } from "@storybook/vue3-vite";
import type { Props } from "../types.ts";
interface UEmptyArgs extends Props {
slotTemplate?: string;
enum: "size";
}
export default {
id: "4090",
title: "Text & Content / Empty",
component: UEmpty,
args: {
title: "No contacts",
},
argTypes: {
...getArgTypes(UEmpty.__name),
},
parameters: {
docs: {
...getDocsDescription(UEmpty.__name),
},
},
} as Meta;
const DefaultTemplate: StoryFn<UEmptyArgs> = (args: UEmptyArgs) => ({
components: { UEmpty, UIcon, UButton, UBadge, ULink, UText },
setup: () => ({ args, slots: getSlotNames(UEmpty.__name), emptyInbox }),
template: `
<UEmpty v-bind="args">
${args.slotTemplate || getSlotsFragment("")}
</UEmpty>
`,
});
const EnumTemplate: StoryFn<UEmptyArgs> = (args: UEmptyArgs, { argTypes }) => ({
components: { UEmpty, URow },
setup: () => ({ args, argTypes, getArgs }),
template: `
<URow>
<UEmpty
v-for="option in argTypes?.[args.enum]?.options"
v-bind="getArgs(args, option)"
:key="option"
/>
</URow>
`,
});
export const Default = DefaultTemplate.bind({});
Default.args = {};
export const Description = DefaultTemplate.bind({});
Description.args = { description: "There are no contacts in the list." };
export const Sizes = EnumTemplate.bind({});
Sizes.args = { enum: "size" };
export const HeaderSlot = DefaultTemplate.bind({});
HeaderSlot.args = {
slotTemplate: `
<template
<img :src="emptyInbox" alt="empty" width="300" />
</template>
`,
};
export const DefaultSlot = DefaultTemplate.bind({});
DefaultSlot.args = {
slotTemplate: `
<template
<UText>
<i>Nothing to display here yet</i>. You can <ULink class="inline">add your own</ULink> <b>content</b>
or include custom <b>components</b> to enhance the view.
</UText>
</template>
`,
};
export const FooterSlot = DefaultTemplate.bind({});
FooterSlot.args = {
slotTemplate: `
<template
<UButton
label="Add new one"
size="sm"
color="grayscale"
variant="soft"
/>
</template>
`,
};