vue-badger-accordion
Version:
Badger-Accordion Component for Vue
185 lines (134 loc) • 3.74 kB
Markdown
# vue-badger-accordion
Badger-Accordion Component for Vue 2.0
This package is a wrapper for the badger-accordion made by [Stuart Nelson](https://github.com/stuartjnelson)
Badger-Accordion-Repository:
https://github.com/stuartjnelson/badger-accordion
---
## Installation
### Install package
```bash
npm install vue-badger-accordion --save
```
## Setup
```javascript
import { BadgerAccordion, BadgerAccordionItem } from 'vue-badger-accordion'
```
#### Implement globally
```javascript
Vue.component('BadgerAccordion', BadgerAccordion)
Vue.component('BadgerAccordionItem', BadgerAccordionItem)
```
#### Implement locally
```javascript
export default {
components: {
BadgerAccordion,
BadgerAccordionItem
}
}
```
## Example
```html
<badger-accordion>
<badger-accordion-item>
<template slot="header">First Accordion Header</template>
<template slot="content">First Accordion Content</template>
</badger-accordion-item>
<badger-accordion-item>
<template slot="header">Second Accordion Header</template>
<template slot="content">Second Accordion Content</template>
</badger-accordion-item>
</badger-accordion>
```
Note: You can replace the template-tag with all regular html-tags, just remember to add the slot-parameter.
## Options
Options can be implemented by component property "option".
```html
<badger-accordion :options="{...}">
...
</badger-accordion>
```
A list of available options could be found in the badger-accordion repository
https://github.com/stuartjnelson/badger-accordion#options
## Events
You can handle open/close-Events for each AccordionItem
```html
<badger-accordion>
<badger-accordion-item @open="onOpenItem" @close="onCloseItem">
<template slot="header">First Accordion Header</template>
<template slot="content">First Accordion Content</template>
</badger-accordion-item>
</badger-accordion>
```
```javascript
methods: {
...
onOpenItem() {
// Item opened
},
onCloseItem() {
// Item closed
}
}
```
Thanks to [elbojoloco](https://github.com/elbojoloco) for that change.
## Custom state-indicators/-icons
By default the Accordion-Header shows an state-indicator (+/-).
You can easily disable or replace them with images or your favorite icon-font by set the icon-property.
#### Set Icons - Basic
_with font-library e.g. font-awesome_
```html
<badger-accordion :icons="{opened: '<i class="fas fa-chevron-down"></i>',
closed: '<i class="fas fa-chevron-up"></i>'}">
```
```html
```
_with images_
```html
<badger-accordion :icons="{opened: '<img src="opened.png" />', closed: '<img
src="closed.png"
/>'}">
```
#### Set Icons - Advanced
Sometimes you may want greater control of your the state icon renders. In this case you can pass a vue component in directly to the badger accordion:
```js
const MyComponent = {
template: `
<span class="my-icon">{{ opened ? 'I am open' : ' I am closed' }}</span>
`,
props: {
opened: {
type: Boolean,
default: false
}
}
}
export default {
components: {
BadgerAccodion,
BadgerAccordionItem
},
data() {
return {
iconComponent: MyComponent
}
}
}
```
```html
<badger-accordion iconComponent="iconComponent"></badger-accordion>
```
#### Disable Icons
```html
<badger-accordion :icons="false"></badger-accordion>
```
## Methods
All Methods of badger-accordion are also available. Just add a ref to you accordion and you can access them.
```html
<badger-accordion ref="myAccordion"></badger-accordion>
```
```javascript
this.$refs.myAccordion.open(0)
```
A list of available methods could be found in the badger-accordion repository
https://github.com/stuartjnelson/badger-accordion#methods