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>
This commit is contained in:
Ilya Artamonov
2023-10-23 18:23:14 +03:00
committed by GitHub
parent ea6fcf1a4c
commit d316cf3a12
600 changed files with 16349 additions and 10239 deletions

View File

@@ -1,7 +1,9 @@
<script setup>
import TabsDefaultExample from './tabs/examples/TabsDefaultExample.vue';
import TabsPillsExample from './tabs/examples/TabsPillsExample.vue';
import TabsUnderlineExample from './tabs/examples/TabsUnderlineExample.vue';
import FwbTabsExample from './tabs/examples/FwbTabsExample.vue'
import FwbTabsExampleInteraction from './tabs/examples/FwbTabsExampleInteraction.vue'
import FwbTabsExampleDirective from './tabs/examples/FwbTabsExampleDirective.vue'
import FwbTabsExamplePills from './tabs/examples/FwbTabsExamplePills.vue'
import FwbTabsExampleUnderline from './tabs/examples/FwbTabsExampleUnderline.vue'
</script>
# Vue Tabs - Flowbite
@@ -18,141 +20,161 @@ The tabs component can be used either as an extra navigational hierarchy complem
## Prop - variant (default)
```typescript
export type TabsVariant = 'default' | 'underline' | 'pills'
defineProps({
variant: {
type: String as PropType<TabsVariant>,
default: 'default',
},
})
```
<TabsDefaultExample />
<fwb-tabs-example />
```vue
<template>
<fwb-tabs v-model="activeTab" class="p-5">
<fwb-tab name="first" title="First">
Lorem ipsum dolor...
</fwb-tab>
<fwb-tab name="second" title="Second">
Lorem ipsum dolor...
</fwb-tab>
<fwb-tab name="third" title="Third">
Lorem ipsum dolor...
</fwb-tab>
<fwb-tab name="fourth" title="Fourth" disabled>
Lorem ipsum dolor...
</fwb-tab>
</fwb-tabs>
</template>
<script setup>
import { ref } from 'vue'
import { Tabs, Tab } from 'flowbite-vue'
import { FwbTab, FwbTabs } from 'flowbite-vue'
const activeTab = ref('first')
</script>
<template>
<tabs v-model="activeTab" class="p-5"> <!-- class appends to content DIV for all tabs -->
<tab name="first" title="First">
Lorem...
</tab>
<tab name="second" title="Second">
Lorem...
</tab>
<tab name="third" title="Third">
Lorem...
</tab>
<tab name="fourth" title="Fourth" :disabled="true">
Lorem...
</tab>
</tabs>
</template>
```
## Prop - variant (underline)
<TabsUnderlineExample />
<fwb-tabsExample-underline />
```vue
<template>
<fwb-tabs v-model="activeTab" variant="underline" class="p-5">
<fwb-tab name="first" title="First">
Lorem ipsum dolor...
</fwb-tab>
<fwb-tab name="second" title="Second">
Lorem ipsum dolor...
</fwb-tab>
<fwb-tab name="third" title="Third">
Lorem ipsum dolor...
</fwb-tab>
<fwb-tab name="fourth" title="Fourth" disabled>
Lorem ipsum dolor...
</fwb-tab>
</fwb-tabs>
</template>
<script setup>
import { ref } from 'vue'
import { Tabs, Tab } from 'flowbite-vue'
import { FwbTab, FwbTabs } from 'flowbite-vue'
const activeTab = ref('first')
</script>
<template>
<tabs variant="underline" v-model="activeTab" class="p-5"> <!-- class appends to content DIV for all tabs -->
<tab name="first" title="First">
Lorem...
</tab>
<tab name="second" title="Second">
Lorem...
</tab>
<tab name="third" title="Third">
Lorem...
</tab>
<tab name="fourth" title="Fourth" :disabled="true">
Lorem...
</tab>
</tabs>
</template>
```
## Prop - variant (pills)
<TabsPillsExample />
<fwb-tabs-example-pills />
```vue
<template>
<fwb-tabs v-model="activeTab" variant="pills" class="p-5">
<fwb-tab name="first" title="First" >
Lorem ipsum dolor...
</fwb-tab>
<fwb-tab name="second" title="Second">
Lorem ipsum dolor...
</fwb-tab>
<fwb-tab name="third" title="Third">
Lorem ipsum dolor...
</fwb-tab>
<fwb-tab name="fourth" title="Fourth" disabled>
Lorem ipsum dolor...
</fwb-tab>
</fwb-tabs>
</div>
</template>
<script setup>
import { ref } from 'vue'
import { Tabs, Tab } from 'flowbite-vue'
import { FwbTab, FwbTabs } from 'flowbite-vue'
const activeTab = ref('first')
</script>
<template>
<tabs variant="pills" v-model="activeTab" class="p-5"> <!-- class appends to content DIV for all tabs -->
<tab name="first" title="First">
Lorem...
</tab>
<tab name="second" title="Second">
Lorem...
</tab>
<tab name="third" title="Third">
Lorem...
</tab>
<tab name="fourth" title="Fourth" :disabled="true">
Lorem...
</tab>
</tabs>
</template>
```
## Prop - directive
Use this props if you want to control which directive to use for rendering every tab content
```typescript
export type TabsVariant = 'default' | 'underline' | 'pills'
<fwb-tabs-example-directive />
```vue
<template>
<fwb-tabs v-model="activeTab" directive="show" class="p-5">
<fwb-tab name="first" title="First">
Lorem ipsum dolor...
</fwb-tab>
<fwb-tab name="second" title="Second">
Lorem ipsum dolor...
</fwb-tab>
<fwb-tab name="third" title="Third">
Lorem ipsum dolor...
</fwb-tab>
<fwb-tab name="fourth" title="Fourth" disabled>
Lorem ipsum dolor...
</fwb-tab>
</fwb-tabs>
</template>
defineProps({
directive: {
type: String as PropType<'if' | 'show'>,
default: 'if',
},
})
<script setup>
import { ref } from 'vue'
import { FwbTab, FwbTabs } from 'flowbite-vue'
const activeTab = ref('first')
</script>
```
## Tab pane interaction
You can add `@click:pane` to Tabs component to intercept click on tab pane.
<fwb-tabs-example-interaction />
```vue
<template>
<fwb-tabs @click:pane="handlePaneClick" v-model="activeTab" class="p-5">
<fwb-tab name="first" title="First">
Lorem ipsum dolor...
</fwb-tab>
<fwb-tab name="second" title="Second">
Lorem ipsum dolor...
</fwb-tab>
<fwb-tab name="third" title="Third">
Lorem ipsum dolor...
</fwb-tab>
<fwb-tab name="fourth" title="Fourth" disabled>
Lorem ipsum dolor...
</fwb-tab>
</fwb-tabs>
</template>
<script setup>
import { ref } from 'vue'
import { Tabs, Tab } from 'flowbite-vue'
function handlePaneClick(): void {
console.log("Click!")
}
import { FwbTab, FwbTabs } from 'flowbite-vue'
const activeTab = ref('first')
const handlePaneClick = () => { console.log('Click!') }
</script>
<template>
<tabs variant="pills" v-model="activeTab" class="p-5" @click:pane="handlePaneClick">
<tab name="first" title="First">
Lorem...
</tab>
<tab name="second" title="Second">
Lorem...
</tab>
<tab name="third" title="Third">
Lorem...
</tab>
<tab name="fourth" title="Fourth" :disabled="true">
Lorem...
</tab>
</tabs>
</template>
```
```
## API
### Props
| Name | Values | Default |
|------------|--------------------------------|-----------|
| directive | `if`, `show` | `if` |
| modelValue | `string` | `''` |
| variant | `default`, `underline`, `pill` | `default` |