152 lines
2.8 KiB
Vue
152 lines
2.8 KiB
Vue
<template>
|
|
<article>
|
|
<section>
|
|
<h4>Density</h4>
|
|
<veui-radio-group
|
|
v-model="density"
|
|
:items="[
|
|
{ label: 'Compact', value: 'compact' },
|
|
{ label: 'Normal', value: 'normal' },
|
|
{ label: 'Loose', value: 'loose' }
|
|
]"
|
|
/>
|
|
</section>
|
|
<section>
|
|
<h4>Size</h4>
|
|
<veui-radio-group
|
|
v-model="size"
|
|
:items="[
|
|
{ label: 'Medium', value: 'm' },
|
|
{ label: 'Small', value: 's' }
|
|
]"
|
|
/>
|
|
</section>
|
|
<section>
|
|
<veui-table
|
|
:ui="ui"
|
|
:data="data"
|
|
key-field="id"
|
|
>
|
|
<veui-table-column
|
|
field="id"
|
|
title="ID"
|
|
/>
|
|
<veui-table-column
|
|
field="name"
|
|
title="Name"
|
|
/>
|
|
<veui-table-column
|
|
field="bid"
|
|
title="Bid"
|
|
width="160"
|
|
align="right"
|
|
>
|
|
<template #default="{ bid }">
|
|
{{ bid | currency }}
|
|
</template>
|
|
</veui-table-column>
|
|
<veui-table-column
|
|
field="updateDate"
|
|
title="Last updated"
|
|
align="center"
|
|
>
|
|
<template #default="{ updateDate }">
|
|
{{ updateDate | date }}
|
|
</template>
|
|
</veui-table-column>
|
|
<veui-table-column
|
|
field="operation"
|
|
title="Operations"
|
|
>
|
|
<template #default="{ index }">
|
|
<veui-button
|
|
ui="text"
|
|
@click="remove(index)"
|
|
>
|
|
Remove
|
|
</veui-button>
|
|
</template>
|
|
</veui-table-column>
|
|
</veui-table>
|
|
</section>
|
|
</article>
|
|
</template>
|
|
|
|
<script>
|
|
import { Table, Column, RadioGroup, Button } from 'veui'
|
|
|
|
export default {
|
|
components: {
|
|
'veui-table': Table,
|
|
'veui-table-column': Column,
|
|
'veui-radio-group': RadioGroup,
|
|
'veui-button': Button
|
|
},
|
|
filters: {
|
|
currency (value) {
|
|
return '¥' + value.toFixed(2)
|
|
},
|
|
date (value) {
|
|
let [, ...parts] = value.match(/(\d{4})(\d{2})(\d{2})/) || []
|
|
return parts.join('-')
|
|
}
|
|
},
|
|
data () {
|
|
return {
|
|
density: 'normal',
|
|
size: 'm',
|
|
data: [
|
|
{
|
|
id: '3154',
|
|
name: 'Steve Rogers',
|
|
bid: 1024,
|
|
updateDate: '20131117'
|
|
},
|
|
{
|
|
id: '3155',
|
|
name: 'Thor Odinson',
|
|
bid: 598,
|
|
updateDate: '20140214'
|
|
},
|
|
{
|
|
id: '3156',
|
|
name: 'Tony Stark',
|
|
bid: 820,
|
|
updateDate: '20170610'
|
|
},
|
|
{
|
|
id: '3157',
|
|
name: 'Stephen Strange',
|
|
bid: 736,
|
|
updateDate: '20180109'
|
|
}
|
|
]
|
|
}
|
|
},
|
|
computed: {
|
|
ui () {
|
|
return `${this.density} ${this.size}`
|
|
}
|
|
},
|
|
methods: {
|
|
remove (index) {
|
|
this.data.splice(index, 1)
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style lang="less" scoped>
|
|
section {
|
|
margin-bottom: 20px;
|
|
}
|
|
|
|
h4 {
|
|
margin-top: 0;
|
|
}
|
|
|
|
.veui-checkbox {
|
|
margin-right: 20px;
|
|
}
|
|
</style>
|