filebrowser/_assets/src/components/prompts/NewDirPrompt.vue

54 lines
1.2 KiB
Vue
Raw Normal View History

<template>
<div class="prompt">
<h3>New directory</h3>
<p>Write the name of the new directory.</p>
<input autofocus type="text" @keyup.enter="submit" v-model.trim="name">
<div>
<button class="ok" @click="submit">Create</button>
<button class="cancel" @click="$store.commit('showNewDir', false)">Cancel</button>
</div>
</div>
</template>
<script>
import url from '@/utils/url'
import api from '@/utils/api'
export default {
name: 'new-dir-prompt',
data: function () {
return {
name: ''
}
},
methods: {
submit: function (event) {
event.preventDefault()
if (this.new === '') return
let uri = this.$route.path
if (this.$store.state.req.kind !== 'listing') {
uri = url.removeLastDir(uri) + '/'
}
uri += this.name + '/'
uri = uri.replace('//', '/')
// buttons.setLoading('newDir')
api.put(uri)
.then(() => {
// buttons.setDone('newDir')
this.$router.push({ path: uri })
})
.catch(error => {
// buttons.setDone('newDir', false)
console.log(error)
})
this.$store.commit('showNewDir', false)
}
}
}
</script>