* refactor: eslint config adjusted for better diff's * refactor: stricter linting + dependencies updated * refactoring: paragraph component - component - docs * refactoring: heading component - component - docs * Update docs/components/heading.md Co-authored-by: Ilya Artamonov <ilya.sosidka@gmail.com> * refactoring: link component - component - docs * refactoring: image component - component - docs * refactoring: alert component - component - docs * refactoring: avatar component - component - docs * refactoring: removed unnecessary code - component names come from the file name * refactoring: breadcrumb component - component - docs * refactoring: accordion component - component - docs * refactoring: buttom component - component - docs * refactoring: badge component - component - docs * refactoring: card component - component - docs * refactoring: order of components in docs updated * refactoring: unnecessary semicolons removed * refactoring: button group component - component - docs * refactoring: carousel component - component - docs * refactoring: dropdown component - component - docs * refactoring: footer component - component - docs * refactoring:list-group component - component - docs * refactoring: modal component - component - docs * refactoring: navbar component - component - docs * refactoring: pagination component - component - docs * refactoring: progress component - component - docs * refactoring: rating component - component - docs * refactoring: spinner component - component - docs * refactoring: table component - component - docs * refactoring: tabs component - component - docs * feat: Updated pagination examples * lint: Lister fixes * feat: Sidebar component and some fixes * feat: Input component * feat: Some fixes * feat: Some fixes * chore: update deps * refactor: removed old Modal component * refactor: radio component and some fixes * fix: fixed path error * refactor: Range component * refactoring: timeline component - component - docs * refactor: Select component * refactoring: toast component - component - docs * refactoring: tooltip component - component - docs * refactoring: sidebar component - component - docs * refactoring: input component - component - docs * refactoring: fileInput component - component - docs * refactoring: select component - component - docs * refactoring: textarea component - component - docs * refactoring: checkbox component - component - docs * refactoring: radio component - component - docs * refactoring: toggle component - component - docs * refactoring: range component - component - docs * local configs linted * documentation quick start updated * flowbite-themable refactored to fit new linters and style guide * random linter fixes * refactoring: toast-provider component - component - docs * final linter fixes * lint: Linter fixes * fix: Fixed types * fix: Fixed card component * docs: Updated card examples * fix: Fixed tabs * refactor: Heading component refactoring * Fwb rename - few fixes after component review (#237) * fix: button documentation * fix: model type in range examples * chore: Toast marked as WIP --------- Co-authored-by: Sqrcz <naorniakowski@slashlab.pl> Co-authored-by: Sqrcz <naorniakowski@gmail.com>
2.5 KiB
2.5 KiB
<script setup>
import FwbFileInputExample from './fileInput/examples/FwbFileInputExample.vue'
import FwbFileInputExampleHelper from './fileInput/examples/FwbFileInputExampleHelper.vue'
import FwbFileInputExampleSize from './fileInput/examples/FwbFileInputExampleSize.vue'
import FwbFileInputExampleDropZone from './fileInput/examples/FwbFileInputExampleDropZone.vue'
import FwbFileInputExampleMultiple from './fileInput/examples/FwbFileInputExampleMultiple.vue'
</script>
Vue FileInput - Flowbite
Get started with the file input component to let the user to upload one or more files from their device storage based on multiple styles and sizes
:::tip Original reference: https://flowbite.com/docs/forms/file-input/ :::
File upload example
```vue <script setup> import { ref } from 'vue' import { FwbFileInput } from 'flowbite-vue' const file = ref(null) </script>
## Multiple File upload
<fwb-file-input-example-multiple />
```vue
<template>
<fwb-file-input v-model="files" label="Upload file" multiple />
<div v-if="files.length !== 0" class="mt-4 border-[1px] border-gray-300 dark:border-gray-600 p-2 rounded-md">
<div v-for="file in files" :key="file">
{{ file.name }}
</div>
</div>
</template>
<script setup>
import { ref } from 'vue'
import { FwbFileInput } from 'flowbite-vue'
const files = ref([])
</script>
Helper text
```vueSVG, PNG, JPG or GIF (MAX. 800x400px).
<script setup> import { ref } from 'vue' import { FwbFileInput } from 'flowbite-vue' const file = ref(null) </script>
## Sizes
<fwb-file-input-example-size />
```vue
<template>
<fwb-file-input v-model="file" label="Small size" size="xs" />
<fwb-file-input v-model="file" label="Default size" size="sm" />
<fwb-file-input v-model="file" label="Large size" size="lg" />
</template>
<script setup>
import { ref } from 'vue'
import { FwbFileInput } from 'flowbite-vue'
const file = ref(null)
</script>
Dropone
```vue <script setup> import { ref } from 'vue' import { FwbFileInput } from 'flowbite-vue' const file = ref(null) </script>