mirror of
https://github.com/tusen-ai/naive-ui.git
synced 2025-01-24 12:45:18 +08:00
1.7 KiB
1.7 KiB
Controlled File List
Example is only a joke.
<n-upload
action="http://www.mocky.io/v2/5e4bafc63100007100d8b70f"
:file-list="fileList"
@change="handleUploadChange"
@remove="handleRemove"
>
<n-button>Upload File</n-button>
</n-upload>
export default {
inject: ['message'],
data () {
return {
fileList: [
{
id: 'url-test',
name: 'URL Test',
url: 'http://www.mocky.io/v2/5e4bafc63100007100d8b70f',
status: 'finished'
},
{
id: 'text-message',
name: 'Your text messages',
status: 'error',
},
{
id: 'notification',
name: 'You notifications',
status: 'finished'
},
{
id: 'contact',
name: 'You contact info',
status: 'finished'
}
]
}
},
methods: {
handleUploadChange ({
fileList
}) {
this.fileList = fileList
},
handleRemove ({ file, fileList }) {
if (file.id === 'text-message') {
this.message.info('Oops... It\'s now uploaded. Okay, delete it.')
} else if (file.id === 'notification') {
this.message.error('No, this is useful for us. Removal not allowed.')
return false
} else if (file.id === 'contact') {
const message = this.message.loading('Don\' know whether it is useful for us, let me ask the server', {
duration: 4000
})
return new Promise(resolve => {
setTimeout(() => {
this.message.error('Oh no, they said you can\'t delete it too!')
resolve(false)
}, 4000)
})
}
}
}
}