vueless
Version:
Vue Styleless UI Component Library, powered by Tailwind CSS.
155 lines (134 loc) • 3.77 kB
text/typescript
import {
getArgTypes,
getSlotNames,
getSlotsFragment,
getDocsDescription,
} from "../../utils/storybook.ts";
import UInputFile from "../../ui.form-input-file/UInputFile.vue";
import UCol from "../../ui.container-col/UCol.vue";
import UBadge from "../../ui.text-badge/UBadge.vue";
import UIcon from "../../ui.image-icon/UIcon.vue";
import type { Meta, StoryFn } from "@storybook/vue3";
import type { Props } from "../types.ts";
interface UInputFileArgs extends Props {
slotTemplate?: string;
enum: "labelAlign" | "size";
}
export default {
id: "3200",
title: "Form Inputs & Controls / Input File",
component: UInputFile,
args: {
label: "Choose a file to upload",
files: [],
},
argTypes: {
...getArgTypes(UInputFile.__name),
},
parameters: {
docs: {
...getDocsDescription(UInputFile.__name),
},
},
} as Meta;
const DefaultTemplate: StoryFn<UInputFileArgs> = (args: UInputFileArgs) => ({
components: { UInputFile, UBadge },
setup() {
const slots = getSlotNames(UInputFile.__name);
return { args, slots };
},
template: `
<UInputFile v-bind="args" v-model="args.files">
${args.slotTemplate || getSlotsFragment("")}
</UInputFile>
`,
});
const EnumVariantTemplate: StoryFn<UInputFileArgs> = (args: UInputFileArgs, { argTypes }) => ({
components: { UInputFile, UCol },
setup() {
return {
args,
options: argTypes?.[args.enum]?.options,
};
},
template: `
<UCol gap="xl">
<div v-for="(option, index) in options" :key="index">
<UInputFile
v-bind="args"
:[args.enum]="option"
:label="option"
/>
</div>
</UCol>
`,
});
export const Default = DefaultTemplate.bind({});
Default.args = {};
export const Description = DefaultTemplate.bind({});
Description.args = { description: "Ensure the document is clear and readable before uploading." };
export const Error = DefaultTemplate.bind({});
Error.args = { error: "Upload failed. Please try again later." };
export const Disabled = DefaultTemplate.bind({});
Disabled.args = { disabled: true };
export const Multiple = DefaultTemplate.bind({});
Multiple.args = { multiple: true };
export const MaxFileSize = DefaultTemplate.bind({});
MaxFileSize.args = {
description: "File size limit is 5 MB.",
maxFileSize: 5,
};
export const AllowedFileTypes = DefaultTemplate.bind({});
AllowedFileTypes.args = {
allowedFileTypes: ["png", "jpeg"],
description: "Only png and jpeg formats are allowed.",
};
export const Sizes = EnumVariantTemplate.bind({});
Sizes.args = { enum: "size" };
export const LabelAlign = EnumVariantTemplate.bind({});
LabelAlign.args = { enum: "labelAlign" };
export const SlotLabel = DefaultTemplate.bind({});
SlotLabel.args = {
slotTemplate: `
<template
<UBadge :label="label" />
</template>
`,
};
export const Slots: StoryFn<UInputFileArgs> = (args) => ({
components: { UInputFile, UCol, UBadge, UIcon },
setup() {
return { args };
},
template: `
<UCol>
<UInputFile
v-bind="args"
v-model="args.files"
label="Slot Top"
>
<template
<UBadge label="Pending Review..." />
</template>
</UInputFile>
<UInputFile
v-bind="args"
v-model="args.files"
label="Slot Left"
>
<template
<UIcon name="info" color="orange" />
</template>
</UInputFile>
<UInputFile
v-bind="args"
v-model="args.files"
label="Slot Bottom"
>
<template
<UBadge label="An antivirus check will be performed after file upload." />
</template>
</UInputFile>
</UCol>
`,
});