vueless
Version:
Vue Styleless UI Component Library, powered by Tailwind CSS.
119 lines (103 loc) • 2.67 kB
text/typescript
import {
getArgs,
getArgTypes,
getSlotNames,
getSlotsFragment,
getDocsDescription,
} from "../../utils/storybook.ts";
import UFile from "../../ui.text-file/UFile.vue";
import URow from "../../ui.container-row/URow.vue";
import UIcon from "../../ui.image-icon/UIcon.vue";
import UBadge from "../../ui.text-badge/UBadge.vue";
import imageURL from "./assets/imageURL.png";
import type { Meta, StoryFn } from "@storybook/vue3-vite";
import type { Props } from "../types.ts";
interface UFileArgs extends Props {
slotTemplate?: string;
enum: "size";
}
export default {
id: "4070",
title: "Text & Content / File",
component: UFile,
args: {
label: "Invoice_123.pdf",
url: "",
},
argTypes: {
...getArgTypes(UFile.__name),
},
parameters: {
docs: {
...getDocsDescription(UFile.__name),
},
},
} as Meta;
const DefaultTemplate: StoryFn<UFileArgs> = (args: UFileArgs) => ({
components: { UFile },
setup() {
const slots = getSlotNames(UFile.__name);
function showAlert() {
return alert("File removed");
}
return { args, slots, showAlert };
},
template: `
<UFile v-bind="args" @remove="() => showAlert()">
${args.slotTemplate || getSlotsFragment("")}
</UFile>
`,
});
const EnumTemplate: StoryFn<UFileArgs> = (args: UFileArgs, { argTypes }) => ({
components: { UFile, URow },
setup: () => ({ args, argTypes, getArgs }),
template: `
<URow>
<UFile
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 ImageURL = DefaultTemplate.bind({});
ImageURL.args = { imageUrl: imageURL };
export const Removable = DefaultTemplate.bind({});
Removable.args = { removable: true };
export const Sizes = EnumTemplate.bind({});
Sizes.args = { enum: "size" };
export const Slots: StoryFn<UFileArgs> = (args) => ({
components: { UFile, URow, UBadge, UIcon },
setup() {
return { args };
},
template: `
<URow gap="lg">
<UFile v-bind="args">
<template
<UIcon
name="info"
color="warning"
size="xs"
class="hover:cursor-default"
/>
</template>
</UFile>
<UFile v-bind="args">
<template
<UBadge
label="File uploaded"
color="success"
size="sm"
variant="soft"
right-icon="done_all"
class="hover:cursor-default"
/>
</template>
</UFile>
</URow>
`,
});