Files
flowbite-vue/docs/components/fileInput.md
Ilya Artamonov d316cf3a12 Components renaming (#225)
* 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>
2023-10-23 18:23:14 +03:00

108 lines
2.5 KiB
Markdown

<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/](https://flowbite.com/docs/forms/file-input/)
:::
## File upload example
<fwb-file-input-example />
```vue
<template>
<fwb-file-input v-model="file" label="Upload file" />
</template>
<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
<fwb-file-input-example-helper />
```vue
<template>
<fwb-file-input v-model="file" label="Upload file">
<p class="!mt-1 text-sm text-gray-500 dark:text-gray-300">
SVG, PNG, JPG or GIF (MAX. 800x400px).
</p>
</fwb-file-input>
</template>
<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
<fwb-file-input-example-drop-zone />
```vue
<template>
<fwb-file-input v-model="file" dropzone />
</template>
<script setup>
import { ref } from 'vue'
import { FwbFileInput } from 'flowbite-vue'
const file = ref(null)
</script>
```