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

54 lines
1.2 KiB
Vue

<template>
<div class="prompt">
<h3>New file</h3>
<p>Write the name of the new file.</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('closeHovers')">Cancel</button>
</div>
</div>
</template>
<script>
import url from '@/utils/url'
import api from '@/utils/api'
export default {
name: 'new-file',
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('newFile')
api.put(uri)
.then(() => {
// buttons.setDone('newFile')
this.$router.push({ path: uri })
})
.catch(error => {
// buttons.setDone('newFile', false)
console.log(error)
})
this.$store.commit('closeHovers')
}
}
}
</script>