2
0
mirror of https://github.com/frappe/books.git synced 2025-01-13 11:15:49 +00:00
books/ui/components/controls/File.vue
2018-07-15 19:20:24 +05:30

61 lines
1.4 KiB
Vue

<script>
import Base from './Base';
export default {
extends: Base,
computed: {
inputClass() {
return ['d-none'];
}
},
methods: {
getWrapperElement(h) {
let fileName = this.docfield.placeholder || this._('Choose a file..');
if (this.$refs.input && this.$refs.input.files.length) {
fileName = this.$refs.input.files[0].name;
}
const fileButton = h('button', {
class: ['btn btn-outline-secondary btn-block'],
domProps: {
textContent: fileName
},
attrs: {
type: 'button'
},
on: {
click: () => this.$refs.input.click()
}
});
return h('div', {
class: ['form-group', ...this.wrapperClass],
attrs: {
'data-fieldname': this.docfield.fieldname
}
}, [this.getLabelElement(h), this.getInputElement(h), fileButton]);
},
getInputAttrs() {
return {
id: this.id,
type: 'file',
value: this.value,
required: this.docfield.required,
disabled: this.disabled,
webkitdirectory: this.docfield.directory,
directory: this.docfield.directory,
accept: (this.docfield.filetypes || []).join(',')
};
},
getInputListeners() {
return {
change: e => {
this.handleChange(e.target.files);
}
};
}
}
};
</script>