SelectButton doc added
parent
2d56117759
commit
39b113fa9f
|
@ -18,11 +18,11 @@ export default {
|
||||||
props: {
|
props: {
|
||||||
value: null,
|
value: null,
|
||||||
options: Array,
|
options: Array,
|
||||||
|
optionLabel: null,
|
||||||
|
multiple: Boolean,
|
||||||
disabled: Boolean,
|
disabled: Boolean,
|
||||||
dataKey: null,
|
dataKey: null,
|
||||||
name: String,
|
name: String,
|
||||||
multiple: Boolean,
|
|
||||||
optionLabel: null,
|
|
||||||
optionValue: null,
|
optionValue: null,
|
||||||
optionDisabled: null
|
optionDisabled: null
|
||||||
},
|
},
|
||||||
|
@ -86,7 +86,7 @@ export default {
|
||||||
this.focusedIndex = index;
|
this.focusedIndex = index;
|
||||||
this.$emit('focus', event);
|
this.$emit('focus', event);
|
||||||
},
|
},
|
||||||
onBlur() {
|
onBlur(event) {
|
||||||
this.focusedIndex = null
|
this.focusedIndex = null
|
||||||
this.$emit('blur', event);
|
this.$emit('blur', event);
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,10 +27,14 @@
|
||||||
</SelectButton>
|
</SelectButton>
|
||||||
<p>Selected Car: <span style="font-weight: bold">{{selectedCar}}</span></p>
|
<p>Selected Car: <span style="font-weight: bold">{{selectedCar}}</span></p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<SelectButtonDoc/>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
import SelectButtonDoc from './SelectButtonDoc';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
@ -51,6 +55,9 @@ export default {
|
||||||
},
|
},
|
||||||
created() {
|
created() {
|
||||||
this.selectedCar = this.cars[1];
|
this.selectedCar = this.cars[1];
|
||||||
|
},
|
||||||
|
components: {
|
||||||
|
'SelectButtonDoc': SelectButtonDoc
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
|
@ -0,0 +1,226 @@
|
||||||
|
<template>
|
||||||
|
<div class="content-section documentation">
|
||||||
|
<TabView>
|
||||||
|
<TabPanel header="Documentation">
|
||||||
|
<h3>Import</h3>
|
||||||
|
<CodeHighlight lang="javascript">
|
||||||
|
import SelectButton from 'primevue/selectbutton';
|
||||||
|
</CodeHighlight>
|
||||||
|
|
||||||
|
<h3>Getting Started</h3>
|
||||||
|
<p>SelectButton requires a value to bind, optionLabel and a collection of options. How to define the options property; Providing an array of arbitrary objects along with the <i>optionLabel</i> property to specify the field name of the option.</p>
|
||||||
|
<CodeHighlight>
|
||||||
|
<SelectButton v-model="selectedCity" :options="cities" optionLabel="name" />
|
||||||
|
</CodeHighlight>
|
||||||
|
|
||||||
|
<CodeHighlight lang="js">
|
||||||
|
export default {
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
selectedCity: null,
|
||||||
|
cities: [
|
||||||
|
{name: 'London', code: 'LND'},
|
||||||
|
{name: 'Paris', code: 'PRS'},
|
||||||
|
{name: 'Rome', code: 'RM'}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</CodeHighlight>
|
||||||
|
|
||||||
|
<h3>Multiple</h3>
|
||||||
|
<p>SelectButton allows selecting only one item by default and setting <i>multiple</i> option enables choosing more than one item. In multiple case, model property should be an array.</p>
|
||||||
|
<CodeHighlight>
|
||||||
|
<SelectButton v-model="selectedCity" :options="cities" optionLabel="brand" :multiple="true" />
|
||||||
|
</CodeHighlight>
|
||||||
|
|
||||||
|
<h3>Disabled Options</h3>
|
||||||
|
<p>Particular options can be prevented from selection using the optionDisabled property.</p>
|
||||||
|
|
||||||
|
<h3>Templating</h3>
|
||||||
|
<p>Items support templating to display custom content inside the buttons using an template that receives the option as the implicit variable. </p>
|
||||||
|
<CodeHighlight>
|
||||||
|
<template v-pre>
|
||||||
|
<SelectButton v-model="selectedCar" :options="cars" optionLabel="brand">
|
||||||
|
<template #option="slotProps">
|
||||||
|
<div style="text-align: center; padding: 1em; width: 125px">
|
||||||
|
<img :alt="slotProps.option.brand" :src="'/demo/images/car/' + slotProps.option.brand + '.png'" style="width:48px" />
|
||||||
|
<div style="margin-top: 1em">{{slotProps.option.brand}}</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</SelectButton>
|
||||||
|
</template>
|
||||||
|
</CodeHighlight>
|
||||||
|
|
||||||
|
<h3>Properties</h3>
|
||||||
|
<div class="doc-tablewrapper">
|
||||||
|
<table class="doc-table">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th>Name</th>
|
||||||
|
<th>Type</th>
|
||||||
|
<th>Default</th>
|
||||||
|
<th>Description</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
<tr>
|
||||||
|
<td>value</td>
|
||||||
|
<td>any</td>
|
||||||
|
<td>null</td>
|
||||||
|
<td>Value of the component.</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>options</td>
|
||||||
|
<td>array</td>
|
||||||
|
<td>null</td>
|
||||||
|
<td>An array of objects to display as the available options.</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>optionLabel</td>
|
||||||
|
<td>string</td>
|
||||||
|
<td>null</td>
|
||||||
|
<td>Name of the label field of an option when an arbitrary objects instead of SelectItems are used as options.</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>multiple</td>
|
||||||
|
<td>boolean</td>
|
||||||
|
<td>false</td>
|
||||||
|
<td>When specified, allows selecting multiple values.</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>disabled</td>
|
||||||
|
<td>boolean</td>
|
||||||
|
<td>false</td>
|
||||||
|
<td>When present, it specifies that the element should be disabled.</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>dataKey</td>
|
||||||
|
<td>string</td>
|
||||||
|
<td>null</td>
|
||||||
|
<td>A property to uniquely match the value in options for better performance.</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>name</td>
|
||||||
|
<td>string</td>
|
||||||
|
<td>null</td>
|
||||||
|
<td>???</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>optionValue</td>
|
||||||
|
<td>any</td>
|
||||||
|
<td>null</td>
|
||||||
|
<td>???</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>optionDisabled</td>
|
||||||
|
<td>boolean</td>
|
||||||
|
<td>null</td>
|
||||||
|
<td>???</td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<h3>Events</h3>
|
||||||
|
<div class="doc-tablewrapper">
|
||||||
|
<table class="doc-table">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th>Name</th>
|
||||||
|
<th>Parameters</th>
|
||||||
|
<th>Description</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
<tr>
|
||||||
|
<td>input</td>
|
||||||
|
<td>event: Single value or an array of values that are selected.</td>
|
||||||
|
<td>Callback to invoke on value change.</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>focus</td>
|
||||||
|
<td>event: Browser event</td>
|
||||||
|
<td>Callback to invoke on focus.</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>blur</td>
|
||||||
|
<td>event: Browser event</td>
|
||||||
|
<td>Callback to invoke on blur.</td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<h3>Dependencies</h3>
|
||||||
|
<p>None.</p>
|
||||||
|
</TabPanel>
|
||||||
|
|
||||||
|
<TabPanel header="Source">
|
||||||
|
<a href="https://github.com/primefaces/primevue/tree/master/src/views/selectbutton" class="btn-viewsource" target="_blank" rel="noopener noreferrer">
|
||||||
|
<span>View on GitHub</span>
|
||||||
|
</a>
|
||||||
|
<CodeHighlight>
|
||||||
|
<template v-pre>
|
||||||
|
<template>
|
||||||
|
<div>
|
||||||
|
<div class="content-section introduction">
|
||||||
|
<div class="feature-intro">
|
||||||
|
<h1>SelectButton</h1>
|
||||||
|
<p>SelectButton is a form component to choose a value from a list of options using button elements.</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="content-section implementation">
|
||||||
|
<h3 class="first">Single</h3>
|
||||||
|
<SelectButton v-model="selectedCity" :options="cities" optionLabel="name" />
|
||||||
|
<p>Selected City: <span style="font-weight: bold">{{selectedCity}}</span></p>
|
||||||
|
|
||||||
|
<h3>Multiple</h3>
|
||||||
|
<SelectButton v-model="selectedCars" :options="cars" optionLabel="brand" :multiple="true" />
|
||||||
|
<p>Selected Cars: <span style="font-weight: bold">{{selectedCars}}</span></p>
|
||||||
|
|
||||||
|
<h3>Custom Content</h3>
|
||||||
|
<SelectButton v-model="selectedCar" :options="cars" optionLabel="brand">
|
||||||
|
<template #option="slotProps">
|
||||||
|
<div style="text-align: center; padding: 1em; width: 125px">
|
||||||
|
<img :alt="slotProps.option.brand" :src="'/demo/images/car/' + slotProps.option.brand + '.png'" style="width:48px" />
|
||||||
|
<div style="margin-top: 1em">{{slotProps.option.brand}}</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</SelectButton>
|
||||||
|
<p>Selected Car: <span style="font-weight: bold">{{selectedCar}}</span></p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</template>
|
||||||
|
</CodeHighlight>
|
||||||
|
|
||||||
|
<CodeHighlight lang="javascript">
|
||||||
|
export default {
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
selectedCity: null,
|
||||||
|
selectedCar: null,
|
||||||
|
selectedCars: null,
|
||||||
|
cities: [
|
||||||
|
{name: 'London', code: 'LND'},
|
||||||
|
{name: 'Paris', code: 'PRS'},
|
||||||
|
{name: 'Rome', code: 'RM'}
|
||||||
|
],
|
||||||
|
cars: [
|
||||||
|
{brand: 'Audi', key: 'A'},
|
||||||
|
{brand: 'Bmw', key: 'B'},
|
||||||
|
{brand: 'Mercedes', key: 'M'}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
created() {
|
||||||
|
this.selectedCar = this.cars[1];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</CodeHighlight>
|
||||||
|
</TabPanel>
|
||||||
|
</TabView>
|
||||||
|
</div>
|
||||||
|
</template>
|
Loading…
Reference in New Issue